summaryrefslogtreecommitdiff
authorharlekin <harlekin>2003-03-21 22:29:00 (UTC)
committer harlekin <harlekin>2003-03-21 22:29:00 (UTC)
commit43b0fded770624c907aae043e88449f80040d7df (patch) (unidiff)
tree37e92b5da66c34323a831586c21a9c23b0abe261
parent07a03b603d964b07d2866e04f480014fadcf1570 (diff)
downloadopie-43b0fded770624c907aae043e88449f80040d7df.zip
opie-43b0fded770624c907aae043e88449f80040d7df.tar.gz
opie-43b0fded770624c907aae043e88449f80040d7df.tar.bz2
added a button for quicklaunch of a default profile
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/apps/opie-console/mainwindow.cpp21
-rw-r--r--noncore/apps/opie-console/mainwindow.h2
-rw-r--r--noncore/apps/opie-console/terminalwidget.cpp26
-rw-r--r--pics/console/konsole_mini.pngbin0 -> 783 bytes
4 files changed, 36 insertions, 13 deletions
diff --git a/noncore/apps/opie-console/mainwindow.cpp b/noncore/apps/opie-console/mainwindow.cpp
index abcdb84..a6fc30b 100644
--- a/noncore/apps/opie-console/mainwindow.cpp
+++ b/noncore/apps/opie-console/mainwindow.cpp
@@ -7,169 +7,177 @@
7#include <qtoolbar.h> 7#include <qtoolbar.h>
8#include <qmessagebox.h> 8#include <qmessagebox.h>
9#include <qpushbutton.h> 9#include <qpushbutton.h>
10#include <qwhatsthis.h> 10#include <qwhatsthis.h>
11#include <qfileinfo.h> 11#include <qfileinfo.h>
12#include <qtextstream.h> 12#include <qtextstream.h>
13 13
14#include <qpe/resource.h> 14#include <qpe/resource.h>
15#include <qpe/qpeapplication.h> 15#include <qpe/qpeapplication.h>
16#include <qpe/filemanager.h> 16#include <qpe/filemanager.h>
17#include <qpe/mimetype.h> 17#include <qpe/mimetype.h>
18 18
19#include <opie/ofiledialog.h> 19#include <opie/ofiledialog.h>
20 20
21#include "TEmulation.h" 21#include "TEmulation.h"
22#include "keytrans.h" 22#include "keytrans.h"
23#include "profileeditordialog.h" 23#include "profileeditordialog.h"
24#include "configdialog.h" 24#include "configdialog.h"
25#include "default.h" 25#include "default.h"
26#include "metafactory.h" 26#include "metafactory.h"
27#include "profile.h" 27#include "profile.h"
28#include "profilemanager.h" 28#include "profilemanager.h"
29#include "mainwindow.h" 29#include "mainwindow.h"
30#include "tabwidget.h" 30#include "tabwidget.h"
31#include "transferdialog.h" 31#include "transferdialog.h"
32#include "function_keyboard.h" 32#include "function_keyboard.h"
33#include "emulation_handler.h" 33#include "emulation_handler.h"
34#include "script.h" 34#include "script.h"
35 35
36 36
37MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) { 37MainWindow::MainWindow(QWidget *parent, const char *name, WFlags) : QMainWindow(parent, name, WStyle_ContextHelp) {
38 KeyTrans::loadAll(); 38 KeyTrans::loadAll();
39 for (int i = 0; i < KeyTrans::count(); i++ ) { 39 for (int i = 0; i < KeyTrans::count(); i++ ) {
40 KeyTrans* s = KeyTrans::find(i ); 40 KeyTrans* s = KeyTrans::find(i );
41 assert( s ); 41 assert( s );
42 } 42 }
43 m_factory = new MetaFactory(); 43 m_factory = new MetaFactory();
44 Default def(m_factory); 44 Default def(m_factory);
45 m_sessions.setAutoDelete( TRUE ); 45 m_sessions.setAutoDelete( TRUE );
46 m_curSession = 0; 46 m_curSession = 0;
47 m_manager = new ProfileManager( m_factory ); 47 m_manager = new ProfileManager( m_factory );
48 m_manager->load(); 48 m_manager->load();
49 m_scriptsData.setAutoDelete(TRUE); 49 m_scriptsData.setAutoDelete(TRUE);
50 50
51 initUI(); 51 initUI();
52 populateProfiles(); 52 populateProfiles();
53 populateScripts(); 53 populateScripts();
54} 54}
55
55void MainWindow::initUI() { 56void MainWindow::initUI() {
56 setToolBarsMovable( FALSE ); 57 setToolBarsMovable( FALSE );
57 58
58 /* tool bar for the menu */ 59 /* tool bar for the menu */
59 m_tool = new QToolBar( this ); 60 m_tool = new QToolBar( this );
60 m_tool->setHorizontalStretchable( TRUE ); 61 m_tool->setHorizontalStretchable( TRUE );
61 62
62 m_bar = new QMenuBar( m_tool ); 63 m_bar = new QMenuBar( m_tool );
63 m_console = new QPopupMenu( this ); 64 m_console = new QPopupMenu( this );
64 m_scripts = new QPopupMenu( this ); 65 m_scripts = new QPopupMenu( this );
65 m_sessionsPop= new QPopupMenu( this ); 66 m_sessionsPop= new QPopupMenu( this );
66 m_scriptsPop = new QPopupMenu( this ); 67 m_scriptsPop = new QPopupMenu( this );
67 68
68 /* add a toolbar for icons */ 69 /* add a toolbar for icons */
69 m_icons = new QToolBar(this); 70 m_icons = new QToolBar(this);
70 71
71 /* 72 /*
72 * the settings action 73 * the settings action
73 */ 74 */
74 m_setProfiles = new QAction(tr("Configure Profiles"), 75 m_setProfiles = new QAction(tr("Configure Profiles"),
75 Resource::loadPixmap( "SettingsIcon" ), 76 Resource::loadPixmap( "SettingsIcon" ),
76 QString::null, 0, this, 0); 77 QString::null, 0, this, 0);
77 m_setProfiles->addTo( m_console ); 78 m_setProfiles->addTo( m_console );
78 connect( m_setProfiles, SIGNAL(activated() ), 79 connect( m_setProfiles, SIGNAL(activated() ),
79 this, SLOT(slotConfigure() ) ); 80 this, SLOT(slotConfigure() ) );
80 81
81 m_console->insertSeparator(); 82 m_console->insertSeparator();
82 /* 83 /*
83 * new Action for new sessions 84 * new Action for new sessions
84 */ 85 */
85 QAction* newCon = new QAction(tr("New Connection"), 86 QAction* newCon = new QAction(tr("New Connection"),
86 Resource::loadPixmap( "new" ), 87 Resource::loadPixmap( "new" ),
87 QString::null, 0, this, 0); 88 QString::null, 0, this, 0);
88 newCon->addTo( m_console ); 89 newCon->addTo( m_console );
89 connect( newCon, SIGNAL(activated() ), 90 connect( newCon, SIGNAL(activated() ),
90 this, SLOT(slotNew() ) ); 91 this, SLOT(slotNew() ) );
91 92
92 m_console->insertSeparator(); 93 m_console->insertSeparator();
93 94
94 QAction *saveCon = new QAction(tr("Save Connection"), 95 QAction *saveCon = new QAction(tr("Save Connection"),
95 Resource::loadPixmap( "save" ), QString::null, 96 Resource::loadPixmap( "save" ), QString::null,
96 0, this, 0 ); 97 0, this, 0 );
97 saveCon->addTo( m_console ); 98 saveCon->addTo( m_console );
98 connect( saveCon, SIGNAL(activated() ), 99 connect( saveCon, SIGNAL(activated() ),
99 this, SLOT(slotSaveSession() ) ); 100 this, SLOT(slotSaveSession() ) );
100 m_console->insertSeparator(); 101 m_console->insertSeparator();
101 102
102 /* 103 /*
103 * connect action 104 * connect action
104 */ 105 */
105 m_connect = new QAction( tr("Connect"), Resource::loadPixmap("console/connected"), 106 m_connect = new QAction( tr("Connect"), Resource::loadPixmap("console/connected"),
106 QString::null, 0, this, 0 ); 107 QString::null, 0, this, 0 );
107 m_connect->addTo( m_console ); 108 m_connect->addTo( m_console );
108 connect(m_connect, SIGNAL(activated() ), 109 connect(m_connect, SIGNAL(activated() ),
109 this, SLOT(slotConnect() ) ); 110 this, SLOT(slotConnect() ) );
110 111
111 /* 112 /*
112 * disconnect action 113 * disconnect action
113 */ 114 */
114 m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"), 115 m_disconnect = new QAction( tr("Disconnect"), Resource::loadPixmap("console/notconnected"),
115 QString::null, 0, this, 0 ); 116 QString::null, 0, this, 0 );
116 m_disconnect->addTo( m_console ); 117 m_disconnect->addTo( m_console );
117 connect(m_disconnect, SIGNAL(activated() ), 118 connect(m_disconnect, SIGNAL(activated() ),
118 this, SLOT(slotDisconnect() ) ); 119 this, SLOT(slotDisconnect() ) );
119 120
120 m_console->insertSeparator(); 121 m_console->insertSeparator();
121 122
123 m_quickLaunch = new QAction( tr("QuickLaunch"), Resource::loadPixmap("console/konsole_mini"), QString::null, 0, this, 0 );
124 m_quickLaunch->addTo( m_icons );
125 connect( m_quickLaunch, SIGNAL( activated() ),
126 this, SLOT( slotQuickLaunch() ) );
127
122 m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null, 128 m_transfer = new QAction( tr("Transfer file..."), Resource::loadPixmap("pass") , QString::null,
123 0, this, 0 ); 129 0, this, 0 );
124 m_transfer->addTo( m_console ); 130 m_transfer->addTo( m_console );
125 connect(m_transfer, SIGNAL(activated() ), 131 connect(m_transfer, SIGNAL(activated() ),
126 this, SLOT(slotTransfer() ) ); 132 this, SLOT(slotTransfer() ) );
127 133
134
135
128 /* 136 /*
129 * immediate change of line wrap policy 137 * immediate change of line wrap policy
130 */ 138 */
131 m_isWrapped = false; 139 m_isWrapped = false;
132 m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 ); 140 m_wrap = new QAction( tr("Line wrap"), Resource::loadPixmap( "linewrap" ), QString::null, 0, this, 0 );
133 m_wrap->addTo( m_console ); 141 m_wrap->addTo( m_console );
134 connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) ); 142 connect( m_wrap, SIGNAL( activated() ), SLOT( slotWrap() ) );
135 143
136 /* 144 /*
137 * fullscreen 145 * fullscreen
138 */ 146 */
139 m_isFullscreen = false; 147 m_isFullscreen = false;
140 148
141 m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" ) 149 m_fullscreen = new QAction( tr("Full screen"), Resource::loadPixmap( "fullscreen" )
142 , QString::null, 0, this, 0); 150 , QString::null, 0, this, 0);
143 m_fullscreen->addTo( m_console ); 151 m_fullscreen->addTo( m_console );
144 connect( m_fullscreen, SIGNAL( activated() ), 152 connect( m_fullscreen, SIGNAL( activated() ),
145 this, SLOT( slotFullscreen() ) ); 153 this, SLOT( slotFullscreen() ) );
146 154
147 m_console->insertSeparator(); 155 m_console->insertSeparator();
148 156
149 QAction *a = new QAction(); 157 QAction *a = new QAction();
150 a->setText( tr("Save history") ); 158 a->setText( tr("Save history") );
151 a->addTo( m_console ); 159 a->addTo( m_console );
152 connect(a, SIGNAL(activated() ), 160 connect(a, SIGNAL(activated() ),
153 this, SLOT(slotSaveHistory() ) ); 161 this, SLOT(slotSaveHistory() ) );
154 /* 162 /*
155 * terminate action 163 * terminate action
156 */ 164 */
157 m_terminate = new QAction(); 165 m_terminate = new QAction();
158 m_terminate->setText( tr("Terminate") ); 166 m_terminate->setText( tr("Terminate") );
159 m_terminate->addTo( m_console ); 167 m_terminate->addTo( m_console );
160 connect(m_terminate, SIGNAL(activated() ), 168 connect(m_terminate, SIGNAL(activated() ),
161 this, SLOT(slotTerminate() ) ); 169 this, SLOT(slotTerminate() ) );
162 170
163 m_closewindow = new QAction(); 171 m_closewindow = new QAction();
164 m_closewindow->setText( tr("Close Window") ); 172 m_closewindow->setText( tr("Close Window") );
165 m_closewindow->addTo( m_console ); 173 m_closewindow->addTo( m_console );
166 connect( m_closewindow, SIGNAL(activated() ), 174 connect( m_closewindow, SIGNAL(activated() ),
167 this, SLOT(slotClose() ) ); 175 this, SLOT(slotClose() ) );
168 176
169 177
170 /* 178 /*
171 * script actions 179 * script actions
172 */ 180 */
173 m_runScript_id = m_scripts->insertItem(tr("Run Script"), m_scriptsPop, -1, 0); 181 m_runScript_id = m_scripts->insertItem(tr("Run Script"), m_scriptsPop, -1, 0);
174 connect(m_scriptsPop, SIGNAL(activated(int)), this, SLOT(slotRunScript(int))); 182 connect(m_scriptsPop, SIGNAL(activated(int)), this, SLOT(slotRunScript(int)));
175 183
@@ -357,153 +365,166 @@ void MainWindow::slotRunScript(int id) {
357 Script script(filePath); 365 Script script(filePath);
358 currentSession()->emulationHandler()->runScript(&script); 366 currentSession()->emulationHandler()->runScript(&script);
359 } 367 }
360} 368}
361 369
362void MainWindow::slotConnect() { 370void MainWindow::slotConnect() {
363 if ( currentSession() ) { 371 if ( currentSession() ) {
364 bool ret = currentSession()->layer()->open(); 372 bool ret = currentSession()->layer()->open();
365 if(!ret) QMessageBox::warning(currentSession()->widgetStack(), 373 if(!ret) QMessageBox::warning(currentSession()->widgetStack(),
366 QObject::tr("Failed"), 374 QObject::tr("Failed"),
367 QObject::tr("Connecting failed for this session.")); 375 QObject::tr("Connecting failed for this session."));
368 else { 376 else {
369 m_connect->setEnabled( false ); 377 m_connect->setEnabled( false );
370 m_disconnect->setEnabled( true ); 378 m_disconnect->setEnabled( true );
371 379
372 // if it does not support file transfer, disable the menu entry 380 // if it does not support file transfer, disable the menu entry
373 if ( ( m_curSession->layer() )->supports()[1] == 0 ) { 381 if ( ( m_curSession->layer() )->supports()[1] == 0 ) {
374 m_transfer->setEnabled( false ); 382 m_transfer->setEnabled( false );
375 } else { 383 } else {
376 m_transfer->setEnabled( true ); 384 m_transfer->setEnabled( true );
377 } 385 }
378 386
379 m_recordScript->setEnabled( true ); 387 m_recordScript->setEnabled( true );
380 m_scripts->setItemEnabled(m_runScript_id, true); 388 m_scripts->setItemEnabled(m_runScript_id, true);
381 } 389 }
382 } 390 }
383} 391}
384 392
385void MainWindow::slotDisconnect() { 393void MainWindow::slotDisconnect() {
386 if ( currentSession() ) { 394 if ( currentSession() ) {
387 currentSession()->layer()->close(); 395 currentSession()->layer()->close();
388 m_connect->setEnabled( true ); 396 m_connect->setEnabled( true );
389 m_disconnect->setEnabled( false ); 397 m_disconnect->setEnabled( false );
390 m_transfer->setEnabled( false ); 398 m_transfer->setEnabled( false );
391 m_recordScript->setEnabled( false); 399 m_recordScript->setEnabled( false);
392 m_saveScript->setEnabled( false ); 400 m_saveScript->setEnabled( false );
393 m_scripts->setItemEnabled(m_runScript_id, false); 401 m_scripts->setItemEnabled(m_runScript_id, false);
394 } 402 }
395} 403}
396 404
397void MainWindow::slotTerminate() { 405void MainWindow::slotTerminate() {
398 if ( currentSession() ) 406 if ( currentSession() )
399 currentSession()->layer()->close(); 407 currentSession()->layer()->close();
400 408
401 slotClose(); 409 slotClose();
402 /* FIXME move to the next session */ 410 /* FIXME move to the next session */
403} 411}
404 412
413void MainWindow::slotQuickLaunch() {
414 Profile prof = manager()->profile( "default" );
415 if ( prof.name() == "default" ) {
416 create( prof );
417 } else {
418 QMessageBox::warning(this, tr("Failure"),tr("please configure one profile named \"default\""));
419 }
420
421}
422
405void MainWindow::slotConfigure() { 423void MainWindow::slotConfigure() {
406 ConfigDialog conf( manager()->all(), factory() ); 424 ConfigDialog conf( manager()->all(), factory() );
407 conf.showMaximized(); 425 conf.showMaximized();
408 426
409 int ret = conf.exec(); 427 int ret = conf.exec();
410 428
411 if ( QDialog::Accepted == ret ) { 429 if ( QDialog::Accepted == ret ) {
412 manager()->setProfiles( conf.list() ); 430 manager()->setProfiles( conf.list() );
413 manager()->save(); 431 manager()->save();
414 populateProfiles(); 432 populateProfiles();
415 } 433 }
416} 434}
417/* 435/*
418 * we will remove 436 * we will remove
419 * this window from the tabwidget 437 * this window from the tabwidget
420 * remove it from the list 438 * remove it from the list
421 * delete it 439 * delete it
422 * and set the currentSession() 440 * and set the currentSession()
423 */ 441 */
424void MainWindow::slotClose() { 442void MainWindow::slotClose() {
425 if (!currentSession() ) 443 if (!currentSession() )
426 return; 444 return;
427 445
428 Session* ses = currentSession(); 446 Session* ses = currentSession();
429 qWarning("removing! currentSession %s", currentSession()->name().latin1() ); 447 qWarning("removing! currentSession %s", currentSession()->name().latin1() );
430 /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */ 448 /* set to NULL to be safe, if its needed slotSessionChanged resets it automatically */
431 m_curSession = NULL; 449 m_curSession = NULL;
432 tabWidget()->remove( /*currentSession()*/ses ); 450 tabWidget()->remove( /*currentSession()*/ses );
433 /*it's autodelete */ 451 /*it's autodelete */
434 m_sessions.remove( ses ); 452 m_sessions.remove( ses );
435 qWarning("after remove!!"); 453 qWarning("after remove!!");
436 454
437 if (!currentSession() ) { 455 if (!currentSession() ) {
438 m_connect->setEnabled( false ); 456 m_connect->setEnabled( false );
439 m_disconnect->setEnabled( false ); 457 m_disconnect->setEnabled( false );
440 m_terminate->setEnabled( false ); 458 m_terminate->setEnabled( false );
441 m_transfer->setEnabled( false ); 459 m_transfer->setEnabled( false );
442 m_recordScript->setEnabled( false ); 460 m_recordScript->setEnabled( false );
443 m_saveScript->setEnabled( false ); 461 m_saveScript->setEnabled( false );
444 m_scripts->setItemEnabled(m_runScript_id, false); 462 m_scripts->setItemEnabled(m_runScript_id, false);
445 m_fullscreen->setEnabled( false ); 463 m_fullscreen->setEnabled( false );
446 m_wrap->setEnabled( false ); 464 m_wrap->setEnabled( false );
447 m_closewindow->setEnabled( false ); 465 m_closewindow->setEnabled( false );
448 } 466 }
449 467
450 m_kb->loadDefaults(); 468 m_kb->loadDefaults();
451} 469}
452 470
453/* 471/*
454 * We will get the name 472 * We will get the name
455 * Then the profile 473 * Then the profile
456 * and then we will make a profile 474 * and then we will make a profile
457 */ 475 */
458void MainWindow::slotProfile( int id) { 476void MainWindow::slotProfile( int id) {
459 Profile prof = manager()->profile( m_sessionsPop->text( id) ); 477 Profile prof = manager()->profile( m_sessionsPop->text( id) );
460 create( prof ); 478 create( prof );
461} 479}
480
481
482
462void MainWindow::create( const Profile& prof ) { 483void MainWindow::create( const Profile& prof ) {
463 if(m_curSession) 484 if(m_curSession)
464 if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide(); 485 if(m_curSession->transferDialog()) m_curSession->transferDialog()->hide();
465 486
466 Session *ses = manager()->fromProfile( prof, tabWidget() ); 487 Session *ses = manager()->fromProfile( prof, tabWidget() );
467 488
468 if((!ses) || (!ses->layer()) || (!ses->widgetStack())) 489 if((!ses) || (!ses->layer()) || (!ses->widgetStack()))
469 { 490 {
470 QMessageBox::warning(this, 491 QMessageBox::warning(this,
471 QObject::tr("Session failed"), 492 QObject::tr("Session failed"),
472 QObject::tr("<qt>Cannot open session: Not all components were found.</qt>")); 493 QObject::tr("<qt>Cannot open session: Not all components were found.</qt>"));
473 //if(ses) delete ses; 494 //if(ses) delete ses;
474 return; 495 return;
475 } 496 }
476 497
477 m_sessions.append( ses ); 498 m_sessions.append( ses );
478 tabWidget()->add( ses ); 499 tabWidget()->add( ses );
479 tabWidget()->repaint(); 500 tabWidget()->repaint();
480 m_curSession = ses; 501 m_curSession = ses;
481 502
482 // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it 503 // dicide if its a local term ( then no connction and no tranfer), maybe make a wrapper method out of it
483 m_connect->setEnabled( true ); 504 m_connect->setEnabled( true );
484 m_disconnect->setEnabled( false ); 505 m_disconnect->setEnabled( false );
485 m_terminate->setEnabled( true ); 506 m_terminate->setEnabled( true );
486 m_fullscreen->setEnabled( true ); 507 m_fullscreen->setEnabled( true );
487 m_wrap->setEnabled( true ); 508 m_wrap->setEnabled( true );
488 m_closewindow->setEnabled( true ); 509 m_closewindow->setEnabled( true );
489 m_transfer->setEnabled( false ); 510 m_transfer->setEnabled( false );
490 m_recordScript->setEnabled( false ); 511 m_recordScript->setEnabled( false );
491 m_saveScript->setEnabled( false ); 512 m_saveScript->setEnabled( false );
492 m_scripts->setItemEnabled(m_runScript_id, false); 513 m_scripts->setItemEnabled(m_runScript_id, false);
493 514
494 // is io_layer wants direct connection, then autoconnect 515 // is io_layer wants direct connection, then autoconnect
495 //if ( ( m_curSession->layer() )->supports()[0] == 1 ) { 516 //if ( ( m_curSession->layer() )->supports()[0] == 1 ) {
496 if (prof.autoConnect()) { 517 if (prof.autoConnect()) {
497 slotConnect(); 518 slotConnect();
498 } 519 }
499 520
500 521
501 QWidget *w = currentSession()->widget(); 522 QWidget *w = currentSession()->widget();
502 if(w) w->setFocus(); 523 if(w) w->setFocus();
503 524
504 if(currentSession()->profile().readNumEntry("Wrap", 80)){ 525 if(currentSession()->profile().readNumEntry("Wrap", 80)){
505 m_isWrapped = true; 526 m_isWrapped = true;
506 } else { 527 } else {
507 m_isWrapped = false; 528 m_isWrapped = false;
508 } 529 }
509 530
diff --git a/noncore/apps/opie-console/mainwindow.h b/noncore/apps/opie-console/mainwindow.h
index 0fac38b..86939c1 100644
--- a/noncore/apps/opie-console/mainwindow.h
+++ b/noncore/apps/opie-console/mainwindow.h
@@ -22,115 +22,117 @@ class Profile;
22class FunctionKeyboard; 22class FunctionKeyboard;
23class FKey; 23class FKey;
24class DocLnk; 24class DocLnk;
25 25
26class MainWindow : public QMainWindow { 26class MainWindow : public QMainWindow {
27 Q_OBJECT 27 Q_OBJECT
28public: 28public:
29 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags fl = 0 ); 29 MainWindow( QWidget *parent = 0, const char *name = 0, WFlags fl = 0 );
30 ~MainWindow(); 30 ~MainWindow();
31 31
32 /** 32 /**
33 * our factory to generate IOLayer and so on 33 * our factory to generate IOLayer and so on
34 * 34 *
35 */ 35 */
36 MetaFactory* factory(); 36 MetaFactory* factory();
37 37
38 /** 38 /**
39 * A session contains a QWidget*, 39 * A session contains a QWidget*,
40 * an IOLayer* and some infos for us 40 * an IOLayer* and some infos for us
41 */ 41 */
42 Session* currentSession(); 42 Session* currentSession();
43 43
44 /** 44 /**
45 * the session list 45 * the session list
46 */ 46 */
47 QList<Session> sessions(); 47 QList<Session> sessions();
48 48
49 /** 49 /**
50 * 50 *
51 */ 51 */
52 ProfileManager* manager(); 52 ProfileManager* manager();
53 TabWidget* tabWidget(); 53 TabWidget* tabWidget();
54 54
55private slots: 55private slots:
56 void slotNew(); 56 void slotNew();
57 void slotConnect(); 57 void slotConnect();
58 void slotDisconnect(); 58 void slotDisconnect();
59 void slotTerminate(); 59 void slotTerminate();
60 void slotConfigure(); 60 void slotConfigure();
61 void slotClose(); 61 void slotClose();
62 void slotProfile(int); 62 void slotProfile(int);
63 void slotTransfer(); 63 void slotTransfer();
64 void slotOpenKeb(bool); 64 void slotOpenKeb(bool);
65 void slotOpenButtons(bool); 65 void slotOpenButtons(bool);
66 void slotRecordScript(); 66 void slotRecordScript();
67 void slotSaveScript(); 67 void slotSaveScript();
68 void slotRunScript(int); 68 void slotRunScript(int);
69 void slotFullscreen(); 69 void slotFullscreen();
70 void slotQuickLaunch();
70 void slotWrap(); 71 void slotWrap();
71 void slotSessionChanged( Session* ); 72 void slotSessionChanged( Session* );
72 void slotKeyReceived(FKey, ushort, ushort, bool); 73 void slotKeyReceived(FKey, ushort, ushort, bool);
73 void slotSaveHistory(); 74 void slotSaveHistory();
74 75
75 /* what could these both slot do? */ 76 /* what could these both slot do? */
76 void slotCopy(); 77 void slotCopy();
77 void slotPaste(); 78 void slotPaste();
78 79
79 /* save the currentSession() to Profiles */ 80 /* save the currentSession() to Profiles */
80 void slotSaveSession(); 81 void slotSaveSession();
81 82
82private: 83private:
83 void initUI(); 84 void initUI();
84 void populateProfiles(); 85 void populateProfiles();
85 void populateScripts(); 86 void populateScripts();
86 void create( const Profile& ); 87 void create( const Profile& );
87 /** 88 /**
88 * the current session 89 * the current session
89 */ 90 */
90 Session* m_curSession; 91 Session* m_curSession;
91 92
92 /** 93 /**
93 * the session list 94 * the session list
94 */ 95 */
95 QList<Session> m_sessions; 96 QList<Session> m_sessions;
96 QList<DocLnk> m_scriptsData; 97 QList<DocLnk> m_scriptsData;
97 98
98 /** 99 /**
99 * the metafactory 100 * the metafactory
100 */ 101 */
101 MetaFactory* m_factory; 102 MetaFactory* m_factory;
102 ProfileManager* m_manager; 103 ProfileManager* m_manager;
103 104
104 TabWidget* m_consoleWindow; 105 TabWidget* m_consoleWindow;
105 QToolBar* m_tool; 106 QToolBar* m_tool;
106 QToolBar* m_icons; 107 QToolBar* m_icons;
107 QToolBar* m_keyBar; 108 QToolBar* m_keyBar;
108 QToolBar* m_buttonBar; 109 QToolBar* m_buttonBar;
109 QMenuBar* m_bar; 110 QMenuBar* m_bar;
110 QPopupMenu* m_console; 111 QPopupMenu* m_console;
111 QPopupMenu* m_sessionsPop; 112 QPopupMenu* m_sessionsPop;
112 QPopupMenu* m_scriptsPop; 113 QPopupMenu* m_scriptsPop;
113 QPopupMenu* m_scripts; 114 QPopupMenu* m_scripts;
114 QAction* m_connect; 115 QAction* m_connect;
115 QAction* m_disconnect; 116 QAction* m_disconnect;
117 QAction* m_quickLaunch;
116 QAction* m_terminate; 118 QAction* m_terminate;
117 QAction* m_transfer; 119 QAction* m_transfer;
118 QAction* m_setProfiles; 120 QAction* m_setProfiles;
119 QAction* m_openKeys; 121 QAction* m_openKeys;
120 QAction* m_openButtons; 122 QAction* m_openButtons;
121 QAction* m_recordScript; 123 QAction* m_recordScript;
122 QAction* m_saveScript; 124 QAction* m_saveScript;
123 QAction* m_fullscreen; 125 QAction* m_fullscreen;
124 QAction* m_wrap; 126 QAction* m_wrap;
125 QAction* m_closewindow; 127 QAction* m_closewindow;
126 128
127 FunctionKeyboard *m_kb; 129 FunctionKeyboard *m_kb;
128 int m_runScript_id; 130 int m_runScript_id;
129 bool m_isFullscreen; 131 bool m_isFullscreen;
130 bool m_isWrapped; 132 bool m_isWrapped;
131 133
132 QWidget* savedParentFullscreen; 134 QWidget* savedParentFullscreen;
133}; 135};
134 136
135 137
136#endif 138#endif
diff --git a/noncore/apps/opie-console/terminalwidget.cpp b/noncore/apps/opie-console/terminalwidget.cpp
index a8cee93..70f7c9b 100644
--- a/noncore/apps/opie-console/terminalwidget.cpp
+++ b/noncore/apps/opie-console/terminalwidget.cpp
@@ -3,118 +3,118 @@
3#include <qcheckbox.h> 3#include <qcheckbox.h>
4#include <qcombobox.h> 4#include <qcombobox.h>
5#include <qradiobutton.h> 5#include <qradiobutton.h>
6#include <qgroupbox.h> 6#include <qgroupbox.h>
7#include <qvbox.h> 7#include <qvbox.h>
8#include <qhgroupbox.h> 8#include <qhgroupbox.h>
9#include <qhbuttongroup.h> 9#include <qhbuttongroup.h>
10#include <qlayout.h> 10#include <qlayout.h>
11#include <qhbox.h> 11#include <qhbox.h>
12 12
13#include "terminalwidget.h" 13#include "terminalwidget.h"
14 14
15namespace { 15namespace {
16 enum TermIds { 16 enum TermIds {
17 id_term_vt100 = 0, 17 id_term_vt100 = 0,
18 id_term_vt102, 18 id_term_vt102,
19 id_term_linux, 19 id_term_linux,
20 id_term_xterm 20 id_term_xterm
21 }; 21 };
22 22
23 enum ColourIds { 23 enum ColourIds {
24 id_term_black, 24 id_term_black,
25 id_term_white, 25 id_term_white,
26 id_term_green, 26 id_term_green,
27 id_term_orange 27 id_term_orange
28 }; 28 };
29 29
30 enum FontIds { 30 enum FontIds {
31 id_size_small, 31 id_size_small,
32 id_size_medium, 32 id_size_medium,
33 id_size_large 33 id_size_large
34 }; 34 };
35}; 35};
36 36
37TerminalWidget::TerminalWidget( const QString& name, QWidget* parent, 37TerminalWidget::TerminalWidget( const QString& name, QWidget* parent,
38 const char* na ) 38 const char* na )
39 : ProfileDialogTerminalWidget( name, parent, na ) { 39 : ProfileDialogTerminalWidget( name, parent, na ) {
40 40
41 m_terminal = new QLabel(tr("Terminal Type"), this ); 41 m_terminal = new QLabel(tr("Terminal Type"), this );
42 m_terminalBox = new QComboBox(this); 42 m_terminalBox = new QComboBox(this);
43 m_colorLabel = new QLabel(tr("Color scheme"), this); 43 m_colorLabel = new QLabel(tr("Color scheme"), this);
44 m_colorCmb = new QComboBox(this ); 44 m_colorCmb = new QComboBox(this );
45 45
46 m_groupSize = new QHButtonGroup(tr("Font size"), this ); 46 m_groupSize = new QHButtonGroup(tr("Font size"), this );
47 m_sizeSmall = new QRadioButton(tr("small"), m_groupSize ); 47 m_sizeSmall = new QRadioButton(tr("small"), m_groupSize );
48 m_sizeMedium = new QRadioButton(tr("medium"), m_groupSize ); 48 m_sizeMedium = new QRadioButton(tr("medium"), m_groupSize );
49 m_sizeLarge = new QRadioButton(tr("large"), m_groupSize ); 49 m_sizeLarge = new QRadioButton(tr("large"), m_groupSize );
50 50
51 m_groupConv = new QHGroupBox(tr("Line-break conversions"), this ); 51 m_groupConv = new QHGroupBox( tr("Line-break conversions"), this );
52 m_convInbound = new QCheckBox(tr("Inbound"), m_groupConv ); 52 m_convInbound = new QCheckBox( tr("Inbound"), m_groupConv );
53 m_convOutbound = new QCheckBox(tr("Outbound"), m_groupConv ); 53 m_convOutbound = new QCheckBox( tr("Outbound"), m_groupConv );
54 54
55 m_groupOptions = new QHGroupBox( tr("Options"), this ); 55 m_groupOptions = new QHGroupBox( tr("Options"), this );
56 m_optionEcho = new QCheckBox(tr("Local echo"), m_groupOptions ); 56 m_optionEcho = new QCheckBox( tr("Local echo"), m_groupOptions );
57 m_optionWrap = new QCheckBox(tr("Line wrap"), m_groupOptions ); 57 m_optionWrap = new QCheckBox( tr("Line wrap"), m_groupOptions );
58 58
59 m_lroot = new QVBoxLayout( this ); 59 m_lroot = new QVBoxLayout( this );
60 m_typeBox = new QVBoxLayout( m_lroot ); 60 m_typeBox = new QVBoxLayout( m_lroot );
61 m_colorBox = new QVBoxLayout( m_lroot ); 61 m_colorBox = new QVBoxLayout( m_lroot );
62 62
63 // Layout 63 // Layout
64 m_typeBox->add(m_terminal ); 64 m_typeBox->add( m_terminal );
65 m_typeBox->add(m_terminalBox ); 65 m_typeBox->add( m_terminalBox );
66 m_lroot->add(m_groupSize ); 66 m_lroot->add( m_groupSize );
67 67
68 m_colorBox->add( m_colorLabel ); 68 m_colorBox->add( m_colorLabel );
69 m_colorBox->add( m_colorCmb ); 69 m_colorBox->add( m_colorCmb );
70 70
71 m_lroot->add(m_groupConv ); 71 m_lroot->add( m_groupConv );
72 m_lroot->add(m_groupOptions ); 72 m_lroot->add( m_groupOptions );
73 m_lroot->addStretch( 0 ); 73 m_lroot->addStretch( 0 );
74 74
75 // Fill in some options 75 // Fill in some options
76 qWarning("Options for terminal box"); 76 qWarning("Options for terminal box");
77 m_terminalBox->insertItem( tr("VT 100"), 0 ); // /*, id_term_vt100*/ ); 77 m_terminalBox->insertItem( tr("VT 100"), 0 ); // /*, id_term_vt100*/ );
78 m_terminalBox->insertItem( tr("VT 102"), 1 ); // /* , id_term_vt102 */); 78 m_terminalBox->insertItem( tr("VT 102"), 1 ); // /* , id_term_vt102 */);
79 m_terminalBox->insertItem( tr("Linux Console"), 2 ); //, id_term_linux ); 79 m_terminalBox->insertItem( tr("Linux Console"), 2 ); //, id_term_linux );
80 m_terminalBox->insertItem( tr("X-Terminal"), 3 ); //, id_term_xterm ); 80 m_terminalBox->insertItem( tr("X-Terminal"), 3 ); //, id_term_xterm );
81 //m_terminalBox->insertItem( tr("ANSI"), id_term_ansi ); 81 //m_terminalBox->insertItem( tr("ANSI"), id_term_ansi );
82 82
83 m_colorCmb->insertItem( tr("black on white"), id_term_black ); 83 m_colorCmb->insertItem( tr("black on white"), id_term_black );
84 m_colorCmb->insertItem( tr("white on black"), id_term_white ); 84 m_colorCmb->insertItem( tr("white on black"), id_term_white );
85 m_colorCmb->insertItem( tr("green on black"), id_term_green ); 85 m_colorCmb->insertItem( tr("green on black"), id_term_green );
86 m_colorCmb->insertItem( tr("orange on black"), id_term_orange ); 86 m_colorCmb->insertItem( tr("orange on black"), id_term_orange );
87 87
88 // signals + slots 88 // signals + slots
89 /* 89 /*
90 connect(m_terminalBox, SIGNAL(activated(int) ), 90 connect(m_terminalBox, SIGNAL(activated(int) ),
91 this, SLOT(slotTermTerm(int) ) ); 91 this, SLOT(slotTermTerm(int) ) );
92 connect(m_colorBox, SIGNAL(activated(int) ), 92 connect(m_colorBox, SIGNAL(activated(int) ),
93 tis, SLOT(slotTermColor(int) ) ); 93 tis, SLOT(slotTermColor(int) ) );
94 connect(m_groupSize, SIGNAL(activated(int) ), 94 connect(m_groupSize, SIGNAL(activated(int) ),
95 this, SLOT(slotTermFont(int) ) ); 95 this, SLOT(slotTermFont(int) ) );
96 96
97 connect(m_optionEcho, SIGNAL(toggled(bool) ), 97 connect(m_optionEcho, SIGNAL(toggled(bool) ),
98 this, SLOT(slotTermEcho(bool) ) ); 98 this, SLOT(slotTermEcho(bool) ) );
99 connect(m_optionWrap, SIGNAL(toggled(bool) ), 99 connect(m_optionWrap, SIGNAL(toggled(bool) ),
100 this, SLOT(slotTermWrap(bool) ) ); 100 this, SLOT(slotTermWrap(bool) ) );
101 connect(m_convInbound, SIGNAL(toggled(bool) ), 101 connect(m_convInbound, SIGNAL(toggled(bool) ),
102 this, SLOT(slotTermInbound(bool) ) ); 102 this, SLOT(slotTermInbound(bool) ) );
103 connect(m_convOutbound, SIGNAL(toggled(bool) ), 103 connect(m_convOutbound, SIGNAL(toggled(bool) ),
104 this, SLOT(slotTermOutbound(bool) ) ); 104 this, SLOT(slotTermOutbound(bool) ) );
105*/ 105*/
106} 106}
107TerminalWidget::~TerminalWidget() { 107TerminalWidget::~TerminalWidget() {
108} 108}
109void TerminalWidget::load( const Profile& prof ) { 109void TerminalWidget::load( const Profile& prof ) {
110 int term = prof.readNumEntry("Terminal"); 110 int term = prof.readNumEntry("Terminal");
111 int color = prof.readNumEntry("Color"); 111 int color = prof.readNumEntry("Color");
112 int fontsize = prof.readNumEntry("Font"); 112 int fontsize = prof.readNumEntry("Font");
113 int opt_echo = prof.readNumEntry("Echo"); 113 int opt_echo = prof.readNumEntry("Echo");
114 int opt_wrap = prof.readNumEntry("Wrap"); 114 int opt_wrap = prof.readNumEntry("Wrap");
115 int opt_inbound = prof.readNumEntry("Inbound"); 115 int opt_inbound = prof.readNumEntry("Inbound");
116 int opt_outbound = prof.readNumEntry("Outbound"); 116 int opt_outbound = prof.readNumEntry("Outbound");
117 117
118 switch( term ) { 118 switch( term ) {
119 case Profile::VT100: 119 case Profile::VT100:
120 m_terminalBox->setCurrentItem(id_term_vt100 ); 120 m_terminalBox->setCurrentItem(id_term_vt100 );
diff --git a/pics/console/konsole_mini.png b/pics/console/konsole_mini.png
new file mode 100644
index 0000000..590a417
--- a/dev/null
+++ b/pics/console/konsole_mini.png
Binary files differ