* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
******************************************************************************/
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
#include "dialogs/mediainfo.hpp"
#include "input_manager.hpp"
#include "dialogs_provider.hpp"
-#include "util/qvlcframe.hpp"
-#include "components/infopanels.hpp"
-#include "qt4.hpp"
#include <QTabWidget>
#include <QGridLayout>
#include <QLineEdit>
#include <QLabel>
-static int ItemChanged( vlc_object_t *p_this, const char *psz_var,
- vlc_value_t oldval, vlc_value_t newval, void *param );
MediaInfoDialog *MediaInfoDialog::instance = NULL;
-MediaInfoDialog::MediaInfoDialog( intf_thread_t *_p_intf, bool _mainInput,
+/* This Dialog has two main modes:
+ - General Mode that shows the current Played item, and the stats
+ - Single mode that shows the info on ONE SINGLE Item on the playlist
+ Please be Careful of not breaking one the modes behaviour... */
+
+MediaInfoDialog::MediaInfoDialog( intf_thread_t *_p_intf,
+ input_item_t *_p_item,
+ bool _mainInput,
bool _stats ) :
QVLCFrame( _p_intf ), mainInput(_mainInput),
stats( _stats )
{
+ p_item = _p_item;
+ b_cleaned = true;
i_runs = 0;
- p_input = NULL;
-
- setWindowTitle( qtr( "Media information" ) );
- resize( 700 , 450 );
- QGridLayout *layout = new QGridLayout( this );
+ setWindowTitle( qtr( "Media Information" ) );
+ resize( 600 , 480 );
+ /* TabWidgets and Tabs creation */
IT = new QTabWidget;
MP = new MetaPanel( IT, p_intf );
IT->addTab( MP, qtr( "&General" ) );
if( stats )
{
ISP = new InputStatsPanel( IT, p_intf );
- IT->addTab( ISP, qtr( "&Stats" ) );
+ IT->addTab( ISP, qtr( "&Statistics" ) );
}
+ QGridLayout *layout = new QGridLayout( this );
+
+ /* No need to use a QDialogButtonBox here */
+ saveMetaButton = new QPushButton( qtr( "&Save Metadata" ) );
+ saveMetaButton->hide();
QPushButton *closeButton = new QPushButton( qtr( "&Close" ) );
closeButton->setDefault( true );
uriLine = new QLineEdit;
- QLabel *uriLabel = new QLabel( qtr( "Location :" ) );
+ QLabel *uriLabel = new QLabel( qtr( "Location:" ) );
- layout->addWidget( IT, 0, 0, 1, 7 );
- layout->addWidget( closeButton, 2, 6 );
+ layout->addWidget( IT, 0, 0, 1, 8 );
layout->addWidget( uriLabel, 1, 0, 1, 1 );
- layout->addWidget( uriLine, 1, 1, 1, 6 );
+ layout->addWidget( uriLine, 1, 1, 1, 7 );
+ layout->addWidget( saveMetaButton, 2, 6 );
+ layout->addWidget( closeButton, 2, 7 );
BUTTONACT( closeButton, close() );
+
+ /* The tabs buttons are shown in the main dialog for space and cosmetics */
+ BUTTONACT( saveMetaButton, saveMeta() );
+
+ /* Let the MetaData Panel update the URI */
CONNECT( MP, uriSet( QString ), uriLine, setText( QString ) );
+ CONNECT( MP, editing(), this, showMetaSaveButton() );
- if( mainInput ) {
- ON_TIMEOUT( update() );
- var_AddCallback( THEPL, "item-change", ItemChanged, this );
+ CONNECT( IT, currentChanged( int ), this, updateButtons( int ) );
+
+ /* If using the General Mode */
+ if( !p_item )
+ {
+ msg_Dbg( p_intf, "Using a general windows" );
+ CONNECT( THEMIM, inputChanged( input_thread_t * ),
+ this, update( input_thread_t * ) );
+
+ if( THEMIM->getInput() )
+ p_item = input_GetItem( THEMIM->getInput() );
}
+
+ /* Call update by hand, so info is shown from current item too */
+ if( p_item )
+ update( p_item, true, true );
+
+ if( stats )
+ ON_TIMEOUT( updateOnTimeOut() );
}
MediaInfoDialog::~MediaInfoDialog()
{
- if( mainInput ) {
- var_DelCallback( THEPL, "item-change", ItemChanged, this );
- }
writeSettings( "mediainfo" );
}
-void MediaInfoDialog::showTab(int i_tab=0)
+void MediaInfoDialog::showTab( int i_tab = 0 )
{
- this->show();
IT->setCurrentIndex( i_tab );
+ show();
}
-static int ItemChanged( vlc_object_t *p_this, const char *psz_var,
- vlc_value_t oldval, vlc_value_t newval, void *param )
+void MediaInfoDialog::showMetaSaveButton()
{
- MediaInfoDialog *p_d = (MediaInfoDialog *)param;
- p_d->need_update = VLC_TRUE;
- return VLC_SUCCESS;
+ saveMetaButton->show();
}
-void MediaInfoDialog::setInput(input_item_t *p_input)
+void MediaInfoDialog::saveMeta()
{
- clear();
- vlc_mutex_lock( &p_input->lock );
- update( p_input, true, true );
- vlc_mutex_unlock( &p_input->lock );
+ MP->saveMeta();
+ saveMetaButton->hide();
}
-void MediaInfoDialog::update()
+/* Function called on inputChanged-update*/
+void MediaInfoDialog::update( input_thread_t *p_input )
{
- /* Timer runs at 150 ms, dont' update more than 2 times per second */
- if( i_runs % 3 != 0 ) return;
- i_runs++;
-
- /* Get Input and clear if non-existant */
- input_thread_t *p_input =
- MainInputManager::getInstance( p_intf )->getInput();
if( !p_input || p_input->b_dead )
{
- clear();
+ if( !b_cleaned )
+ {
+ clear();
+ b_cleaned = true;
+ }
return;
}
+ /* Launch the update in all the panels */
vlc_object_yield( p_input );
- vlc_mutex_lock( &input_GetItem(p_input)->lock );
- update( input_GetItem(p_input), need_update, need_update );
- need_update = false;
+ update( input_GetItem(p_input), true, true);
- vlc_mutex_unlock( &input_GetItem(p_input)->lock );
vlc_object_release( p_input );
}
-void MediaInfoDialog::update( input_item_t *p_item, bool update_info,
- bool update_meta )
+void MediaInfoDialog::updateOnTimeOut()
+{
+ /* Timer runs at 150 ms, dont' update more than 2 times per second */
+ i_runs++;
+ if( i_runs % 4 != 0 ) return;
+
+ /* Get Input and clear if non-existant */
+ input_thread_t *p_input = THEMIM->getInput();
+
+ if( p_input && !p_input->b_dead )
+ {
+ vlc_object_yield( p_input );
+ update( input_GetItem(p_input), false, false);
+ vlc_object_release( p_input );
+ }
+}
+
+void MediaInfoDialog::update( input_item_t *p_item,
+ bool update_info,
+ bool update_meta )
{
if( update_info )
IP->update( p_item );
MP->clear();
EMP->clear();
if( stats ) ISP->clear();
+ b_cleaned = true;
}
void MediaInfoDialog::close()
{
- this->toggleVisible();
+ toggleVisible();
+ /* if dialog is closed, revert editing if not saved */
+ if( MP->isInEditMode() )
+ {
+ MP->setEditMode( false );
+ updateButtons( 0 );
+ }
if( mainInput == false ) {
deleteLater();
}
}
+
+void MediaInfoDialog::updateButtons( int i_tab )
+{
+ if( MP->isInEditMode() && i_tab == 0 )
+ saveMetaButton->show();
+ else
+ saveMetaButton->hide();
+}