1 /*****************************************************************************
2 * main_inteface.cpp : Main interface
3 ****************************************************************************
4 * Copyright (C) 2006 the VideoLAN team
7 * Authors: Clément Stenac <zorglub@videolan.org>
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. *****************************************************************************/
24 #include <QApplication>
25 #include <QSignalMapper>
26 #include <QFileDialog>
29 #include "dialogs_provider.hpp"
30 #include "main_interface.hpp"
32 #include <vlc_intf_strings.h>
35 #include "dialogs/playlist.hpp"
36 #include "dialogs/prefs_dialog.hpp"
37 #include "dialogs/mediainfo.hpp"
38 #include "dialogs/messages.hpp"
39 #include "dialogs/extended.hpp"
40 #include "dialogs/sout.hpp"
41 #include "dialogs/open.hpp"
42 #include "dialogs/help.hpp"
44 DialogsProvider* DialogsProvider::instance = NULL;
46 DialogsProvider::DialogsProvider( intf_thread_t *_p_intf ) :
47 QObject( NULL ), p_intf( _p_intf )
49 fixed_timer = new QTimer( this );
50 fixed_timer->start( 150 /* milliseconds */ );
52 menusMapper = new QSignalMapper();
53 CONNECT( menusMapper, mapped(QObject *), this, menuAction( QObject *) );
55 menusUpdateMapper = new QSignalMapper();
56 CONNECT( menusUpdateMapper, mapped(QObject *),
57 this, menuUpdateAction( QObject *) );
59 SDMapper = new QSignalMapper();
60 CONNECT( SDMapper, mapped (QString), this, SDMenuAction( QString ) );
63 DialogsProvider::~DialogsProvider()
65 PlaylistDialog::killInstance();
66 MediaInfoDialog::killInstance();
69 void DialogsProvider::quit()
71 p_intf->b_die = VLC_TRUE;
75 void DialogsProvider::customEvent( QEvent *event )
77 if( event->type() == DialogEvent_Type )
79 DialogEvent *de = static_cast<DialogEvent*>(event);
80 switch( de->i_dialog )
82 case INTF_DIALOG_FILE:
84 case INTF_DIALOG_DISC:
85 openDiscDialog(); break;
87 openNetDialog(); break;
88 case INTF_DIALOG_CAPTURE:
90 case INTF_DIALOG_PLAYLIST:
91 playlistDialog(); break;
92 case INTF_DIALOG_MESSAGES:
93 messagesDialog(); break;
94 case INTF_DIALOG_PREFS:
96 case INTF_DIALOG_POPUPMENU:
97 case INTF_DIALOG_AUDIOPOPUPMENU:
98 case INTF_DIALOG_VIDEOPOPUPMENU:
99 case INTF_DIALOG_MISCPOPUPMENU:
100 popupMenu( de->i_dialog ); break;
101 case INTF_DIALOG_FILEINFO:
102 mediaInfoDialog(); break;
103 case INTF_DIALOG_INTERACTION:
104 doInteraction( de->p_arg ); break;
105 case INTF_DIALOG_VLM:
106 case INTF_DIALOG_BOOKMARKS:
107 bookmarksDialog(); break;
108 case INTF_DIALOG_WIZARD:
110 msg_Warn( p_intf, "unimplemented dialog\n" );
115 /****************************************************************************
116 * Individual simple dialogs
117 ****************************************************************************/
118 void DialogsProvider::playlistDialog()
120 PlaylistDialog::getInstance( p_intf )->toggleVisible();
123 void DialogsProvider::prefsDialog()
125 PrefsDialog::getInstance( p_intf )->toggleVisible();
127 void DialogsProvider::extendedDialog()
129 ExtendedDialog::getInstance( p_intf )->toggleVisible();
132 void DialogsProvider::messagesDialog()
134 MessagesDialog::getInstance( p_intf )->toggleVisible();
137 void DialogsProvider::helpDialog()
139 HelpDialog::getInstance( p_intf )->toggleVisible();
142 void DialogsProvider::aboutDialog()
144 AboutDialog::getInstance( p_intf )->toggleVisible();
147 void DialogsProvider::mediaInfoDialog()
149 MediaInfoDialog::getInstance( p_intf )->toggleVisible();
152 void DialogsProvider::bookmarksDialog()
156 /****************************************************************************
157 * All the open/add stuff
158 ****************************************************************************/
160 void DialogsProvider::openDialog()
164 void DialogsProvider::openDiscDialog()
168 void DialogsProvider::openNetDialog()
172 void DialogsProvider::openDialog( int i_tab )
174 OpenDialog::getInstance( p_intf->p_sys->p_mi , p_intf )->showTab( i_tab );
177 void DialogsProvider::PLAppendDialog()
180 void DialogsProvider::MLAppendDialog()
185 /**** Simple open ****/
187 QStringList DialogsProvider::showSimpleOpen()
190 FileTypes = _("Media Files");
192 FileTypes += EXTENSIONS_MEDIA;
194 FileTypes += _("Video Files");
196 FileTypes += EXTENSIONS_VIDEO;
198 FileTypes += _("Sound Files");
200 FileTypes += EXTENSIONS_AUDIO;
202 FileTypes += _("PlayList Files");
204 FileTypes += EXTENSIONS_PLAYLIST;
206 FileTypes += _("All Files");
207 FileTypes += " (*.*)";
208 FileTypes.replace(QString(";*"), QString(" *"));
209 return QFileDialog::getOpenFileNames( NULL, qfu(I_OP_SEL_FILES ),
210 p_intf->p_libvlc->psz_homedir, FileTypes );
213 void DialogsProvider::addFromSimple( bool pl, bool go)
215 QStringList files = DialogsProvider::showSimpleOpen();
217 foreach( QString file, files )
219 const char * psz_utf8 = qtu( file );
220 playlist_Add( THEPL, psz_utf8, NULL,
221 go ? ( PLAYLIST_APPEND | ( i ? 0 : PLAYLIST_GO ) |
222 ( i ? PLAYLIST_PREPARSE : 0 ) )
223 : ( PLAYLIST_APPEND | PLAYLIST_PREPARSE ),
225 pl ? VLC_TRUE : VLC_FALSE );
230 void DialogsProvider::simplePLAppendDialog()
232 addFromSimple( true, false );
235 void DialogsProvider::simpleMLAppendDialog()
237 addFromSimple( false, false );
240 void DialogsProvider::simpleOpenDialog()
242 addFromSimple( true, true );
245 void DialogsProvider::openPlaylist()
247 QStringList files = showSimpleOpen();
248 foreach( QString file, files )
250 playlist_Import( THEPL, qtu(file) );
254 void DialogsProvider::savePlaylist()
256 QFileDialog *qfd = new QFileDialog( NULL,
257 qtr("Choose a filename to save playlist"),
258 p_intf->p_libvlc->psz_homedir,
259 qfu("XSPF playlist (*.xspf);; ") +
260 qfu("M3U playlist (*.m3u);; Any (*.*) ") );
261 qfd->setFileMode( QFileDialog::AnyFile );
262 qfd->setAcceptMode( QFileDialog::AcceptSave );
263 qfd->setConfirmOverwrite( true );
265 if( qfd->exec() == QDialog::Accepted )
267 if( qfd->selectedFiles().count() > 0 )
269 char *psz_module, *psz_m3u = "export-m3u",
270 *psz_xspf = "export-xspf";
272 QString file = qfd->selectedFiles().first();
273 QString filter = qfd->selectedFilter();
275 if( file.contains(".xsp") ||
276 ( filter.contains(".xspf") && !file.contains(".m3u") ) )
278 psz_module = psz_xspf;
279 if( !file.contains( ".xsp" ) )
280 file.append( ".xspf" );
284 psz_module = psz_m3u;
285 if( !file.contains( ".m3u" ) )
286 file.append( ".m3u" );
289 playlist_Export( THEPL, qtu(file), THEPL->p_local_category,
296 static void openDirectory( intf_thread_t* p_intf, bool pl, bool go )
298 QString dir = QFileDialog::getExistingDirectory ( 0,
299 _("Open directory") );
300 input_item_t *p_input = input_ItemNewExt( THEPL, qtu(dir), NULL,
302 playlist_AddInput( THEPL, p_input,
303 go ? ( PLAYLIST_APPEND | PLAYLIST_GO ) : PLAYLIST_APPEND,
305 input_Read( THEPL, p_input, VLC_FALSE );
308 void DialogsProvider::PLAppendDir()
310 openDirectory( p_intf, true, false );
313 void DialogsProvider::MLAppendDir()
315 openDirectory( p_intf, false , false );
319 /****************************************************************************
321 ****************************************************************************/
323 void DialogsProvider::streamingDialog()
325 OpenDialog *o = new OpenDialog( p_intf->p_sys->p_mi, p_intf, true );
326 if ( o->exec() == QDialog::Accepted )
328 SoutDialog *s = new SoutDialog( p_intf->p_sys->p_mi, p_intf );
329 if( s->exec() == QDialog::Accepted )
331 msg_Err(p_intf, "mrl %s\n", qta(s->mrl));
333 int i_len = strlen( qtu(s->mrl) ) + 10;
334 char *psz_option = (char*)malloc(i_len);
335 snprintf( psz_option, i_len - 1, ":sout=%s", qtu(s->mrl));
337 playlist_AddExt( THEPL, qtu( o->mrl ), "Streaming",
338 PLAYLIST_APPEND | PLAYLIST_GO, PLAYLIST_END,
339 -1, &psz_option, 1, VLC_TRUE );
346 /****************************************************************************
347 * Menus / Interaction
348 ****************************************************************************/
350 void DialogsProvider::menuAction( QObject *data )
352 QVLCMenu::DoAction( p_intf, data );
355 void DialogsProvider::menuUpdateAction( QObject *data )
357 MenuFunc * f = qobject_cast<MenuFunc *>(data);
361 void DialogsProvider::SDMenuAction( QString data )
363 char *psz_sd = strdup( qtu( data ) );
364 if( !playlist_IsServicesDiscoveryLoaded( THEPL, psz_sd ) )
365 playlist_ServicesDiscoveryAdd( THEPL, psz_sd );
367 playlist_ServicesDiscoveryRemove( THEPL, psz_sd );
373 void DialogsProvider::doInteraction( intf_dialog_args_t *p_arg )
375 InteractionDialog *qdialog;
376 interaction_dialog_t *p_dialog = p_arg->p_dialog;
377 switch( p_dialog->i_action )
380 qdialog = new InteractionDialog( p_intf, p_dialog );
381 p_dialog->p_private = (void*)qdialog;
382 if( !(p_dialog->i_status == ANSWERED_DIALOG) )
385 case INTERACT_UPDATE:
386 qdialog = (InteractionDialog*)(p_dialog->p_private);
391 qdialog = (InteractionDialog*)(p_dialog->p_private);
394 p_dialog->i_status = HIDDEN_DIALOG;
396 case INTERACT_DESTROY:
397 qdialog = (InteractionDialog*)(p_dialog->p_private);
398 if( !p_dialog->i_flags & DIALOG_NONBLOCKING_ERROR )
400 p_dialog->i_status = DESTROYED_DIALOG;
405 void DialogsProvider::switchToSkins()
407 var_SetString( p_intf, "intf-switch", "skins2" );
410 void DialogsProvider::popupMenu( int i_dialog )