X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fgui%2Fqt4%2Fdialogs%2Fhelp.cpp;h=1b135bab2ab3a3ed4fe8db740f9bbb61791dedae;hb=223419069363b3eab712cff2d0ac671a94d8fc65;hp=4d5969a8e515354822dd84e1abac00861bce2002;hpb=801314fc5060d065832cded13dd63a1e59dfe0da;p=vlc diff --git a/modules/gui/qt4/dialogs/help.cpp b/modules/gui/qt4/dialogs/help.cpp index 4d5969a8e5..1b135bab2a 100644 --- a/modules/gui/qt4/dialogs/help.cpp +++ b/modules/gui/qt4/dialogs/help.cpp @@ -1,10 +1,11 @@ /***************************************************************************** * Help.cpp : Help and About dialogs **************************************************************************** - * Copyright (C) 2006 the VideoLAN team - * $Id: Messages.cpp 16024 2006-07-13 13:51:05Z xtophe $ + * Copyright (C) 2007 the VideoLAN team + * $Id$ * * Authors: Jean-Baptiste Kempf + * Rémi Duraffort * * 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 @@ -21,78 +22,151 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/ +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#include + #include "dialogs/help.hpp" +#include + +#ifdef UPDATE_CHECK +#include +#endif #include "dialogs_provider.hpp" -#include "util/qvlcframe.hpp" -#include "qt4.hpp" + +#include #include #include #include #include +#include +#include +#include +#include +#include + HelpDialog *HelpDialog::instance = NULL; -HelpDialog::HelpDialog( intf_thread_t *_p_intf) : QVLCFrame( _p_intf ) +HelpDialog::HelpDialog( intf_thread_t *_p_intf ) : QVLCFrame( _p_intf ) + { setWindowTitle( qtr( "Help" ) ); - resize(600, 500); + setMinimumSize( 250, 300 ); - QGridLayout *layout = new QGridLayout(this); - QTextBrowser *helpBrowser = new QTextBrowser(this); - QPushButton *closeButton = new QPushButton(qtr("&Close")); + 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 ); - layout->addWidget(helpBrowser, 0, 0, 1, 0); - layout->addWidget(closeButton, 1, 3); + layout->addWidget( helpBrowser, 0, 0, 1, 0 ); + layout->addWidget( closeButton, 1, 3 ); BUTTONACT( closeButton, close() ); + readSettings( "Help", QSize( 400, 450 ) ); } HelpDialog::~HelpDialog() { + writeSettings( "Help" ); } + void HelpDialog::close() { - this->toggleVisible(); + toggleVisible(); } AboutDialog *AboutDialog::instance = NULL; -AboutDialog::AboutDialog( intf_thread_t *_p_intf) : QVLCFrame( _p_intf ) +AboutDialog::AboutDialog( QWidget *parent, intf_thread_t *_p_intf) + : QVLCDialog( parent, _p_intf ) { setWindowTitle( qtr( "About" ) ); resize( 600, 500 ); + setMinimumSize( 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( "Infos about VLC media player" ) ); + 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" ) ); + 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 ); - layout->addWidget( introduction, 0, 0, 1, 2 ); - layout->addWidget( tab, 1, 0, 1, 2 ); - layout->addWidget( closeButton, 2, 1, 1, 1 ); + /* Main Introduction */ + QWidget *infoWidget = new QWidget( this ); + QHBoxLayout *infoLayout = new QHBoxLayout( infoWidget ); + QLabel *infoLabel = new QLabel( + 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" + "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" + + qtr( "You are using the Qt4 Interface.\n\n" ) + + qtr( "Copyright (C) " COPYRIGHT_YEARS " 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 */ - QFile *licenseFile = new QFile( "/usr/src/vlc/COPYING" ); - QTextEdit *licenseEdit = new QTextEdit( this ); - licenseEdit->setText( licenseFile->readAll() ); - licenseEdit->setReadOnly( true ); + QTextEdit *licenseEdit = new QTextEdit( this ); + licenseEdit->setText( qfu( psz_license ) ); + licenseEdit->setReadOnly( true ); /* People who helped */ - QFile *thanksFile = new QFile( "/usr/src/vlc/THANKS" ); + QWidget *thanksWidget = new QWidget( this ); + QVBoxLayout *thanksLayout = new QVBoxLayout( thanksWidget ); + + QLabel *thanksLabel = new QLabel( qtr( "We would like to thank the whole " + "VLC community, the testers, our users and the following people " + "(and the missing ones...) for their collaboration to " + "create the best free software." ) ); + thanksLabel->setWordWrap( true ); + thanksLayout->addWidget( thanksLabel ); QTextEdit *thanksEdit = new QTextEdit( this ); - thanksEdit->setText( thanksFile->readAll() ); + thanksEdit->setText( qfu( psz_thanks ) ); thanksEdit->setReadOnly( true ); + thanksLayout->addWidget( thanksEdit ); + + /* 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( NULL, _( "Information" ) ); - tab->addTab( NULL, _( "Authors" ) ); - tab->addTab( thanksEdit, _("Thanks") ); - tab->addTab( licenseEdit, _("Distribution License") ); + tab->addTab( infoWidget, qtr( "About" ) ); + tab->addTab( authorsEdit, qtr( "Authors" ) ); + tab->addTab( thanksWidget, qtr("Thanks") ); + tab->addTab( licenseEdit, qtr("License") ); BUTTONACT( closeButton, close() ); } @@ -100,7 +174,139 @@ AboutDialog::AboutDialog( intf_thread_t *_p_intf) : QVLCFrame( _p_intf ) AboutDialog::~AboutDialog() { } + void AboutDialog::close() { - this->toggleVisible(); + toggleVisible(); +} + +#ifdef UPDATE_CHECK + +/***************************************************************************** + * 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( (QEvent::Type)UDOkEvent ); + else + event = new QEvent( (QEvent::Type)UDErrorEvent ); + + QApplication::postEvent( UDialog, event ); +} + +UpdateDialog *UpdateDialog::instance = NULL; + +UpdateDialog::UpdateDialog( intf_thread_t *_p_intf ) : QVLCFrame( _p_intf ) +{ + setWindowTitle( qtr( "Update" ) ); + + QGridLayout *layout = new QGridLayout( this ); + + 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 ); + + updateLabel = new QLabel( qtr( "Checking for an update..." ) ); + updateLabel->setWordWrap( true ); + + layout->addWidget( updateLabel, 0, 0 ); + layout->addWidget( buttonBox, 1, 0 ); + + BUTTONACT( updateButton, UpdateOrDownload() ); + BUTTONACT( closeButton, close() ); + + /* Create the update structure */ + p_update = update_New( p_intf ); + b_checked = false; + + readSettings( "Update", QSize( 120, 80 ) ); + + /* Check for updates */ + UpdateOrDownload(); +} + +UpdateDialog::~UpdateDialog() +{ + update_Delete( p_update ); + writeSettings( "Update" ); +} + +void UpdateDialog::close() +{ + toggleVisible(); } + +/* Check for updates */ +void UpdateDialog::UpdateOrDownload() +{ + if( !b_checked ) + { + updateButton->setEnabled( false ); + msg_Dbg( p_intf, "Launching an update request" ); + update_Check( p_update, UpdateCallback, this ); + } + else + { + updateButton->setEnabled( false ); + QString dest_dir = QFileDialog::getExistingDirectory( this, + qtr( "Select a directory..." ), + qfu( config_GetHomeDir() ) ); + + if( dest_dir != "" ) + { + toggleVisible(); + update_Download( p_update, qtu( dest_dir ) ); + } + else + updateButton->setEnabled( true ); + } +} + +/* Handle the events */ +void UpdateDialog::customEvent( QEvent *event ) +{ + if( event->type() == UDOkEvent ) + updateNotify( true ); + else + updateNotify( false ); +} + +/* Notify the end of the update_Check */ +void UpdateDialog::updateNotify( bool b_result ) +{ + /* The update finish without errors */ + if( b_result ) + { + if( update_NeedUpgrade( p_update ) ) + { + 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 ) ); + + /* Force the dialog to be shown */ + this->show(); + } + else + updateLabel->setText( qtr( "You have the latest version of VLC" ) ); + } + else + updateLabel->setText( + qtr( "An error occurred while checking for updates" ) ); + + adjustSize(); + updateButton->setEnabled( true ); +} + +#endif +