summaryrefslogtreecommitdiff
authorharlekin <harlekin>2003-03-23 13:14:25 (UTC)
committer harlekin <harlekin>2003-03-23 13:14:25 (UTC)
commit56192a3d601e5364e9b8f4c331d892befb19cbc1 (patch) (unidiff)
tree97966e16e29316a6dc28e2f0c9619192a3757b8f
parentc3b01d2abd00b82b821604827987f2becccf5233 (diff)
downloadopie-56192a3d601e5364e9b8f4c331d892befb19cbc1.zip
opie-56192a3d601e5364e9b8f4c331d892befb19cbc1.tar.gz
opie-56192a3d601e5364e9b8f4c331d892befb19cbc1.tar.bz2
after refresh show the same tab again as before ( for example after a medium is inserted or linkcChanged(QString) has been called
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/launcher/launcher.cpp34
-rw-r--r--core/launcher/launcher.h2
2 files changed, 32 insertions, 4 deletions
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp
index fc944e1..e74301c 100644
--- a/core/launcher/launcher.cpp
+++ b/core/launcher/launcher.cpp
@@ -88,229 +88,250 @@ namespace {
88 if(tmpMime ) 88 if(tmpMime )
89 mimes.append("audio/*" ); 89 mimes.append("audio/*" );
90 90
91 tmpMime = cfg->readBoolEntry("image", true ); 91 tmpMime = cfg->readBoolEntry("image", true );
92 if(tmpMime ) 92 if(tmpMime )
93 mimes.append("image/*" ); 93 mimes.append("image/*" );
94 94
95 tmpMime = cfg->readBoolEntry("text", true ); 95 tmpMime = cfg->readBoolEntry("text", true );
96 if(tmpMime ) 96 if(tmpMime )
97 mimes.append("text/*"); 97 mimes.append("text/*");
98 98
99 tmpMime = cfg->readBoolEntry("video", true ); 99 tmpMime = cfg->readBoolEntry("video", true );
100 if(tmpMime ) 100 if(tmpMime )
101 mimes.append("video/*" ); 101 mimes.append("video/*" );
102 } 102 }
103 return mimes; 103 return mimes;
104 } 104 }
105 105
106} 106}
107 107
108 108
109 109
110//#define SHOW_ALL 110//#define SHOW_ALL
111 111
112class CategoryTab : public QTab 112class CategoryTab : public QTab
113{ 113{
114public: 114public:
115 CategoryTab( const QIconSet &icon, const QString &text=QString::null ) 115 CategoryTab( const QIconSet &icon, const QString &text=QString::null )
116 : QTab( icon, text ) 116 : QTab( icon, text )
117 { 117 {
118 } 118 }
119 119
120 QColor bgColor; 120 QColor bgColor;
121 QColor fgColor; 121 QColor fgColor;
122}; 122};
123 123
124//=========================================================================== 124//===========================================================================
125 125
126CategoryTabWidget::CategoryTabWidget( QWidget* parent ) : 126CategoryTabWidget::CategoryTabWidget( QWidget* parent ) :
127 QVBox( parent ) 127 QVBox( parent )
128{ 128{
129 categoryBar = 0; 129 categoryBar = 0;
130 stack = 0; 130 stack = 0;
131} 131}
132 132
133void CategoryTabWidget::prevTab() 133void CategoryTabWidget::prevTab()
134{ 134{
135 if ( categoryBar ) { 135 if ( categoryBar ) {
136 int n = categoryBar->count(); 136 int n = categoryBar->count();
137 int tab = categoryBar->currentTab(); 137 int tab = categoryBar->currentTab();
138 if ( tab >= 0 ) 138 if ( tab >= 0 )
139 categoryBar->setCurrentTab( (tab - 1 + n)%n ); 139 categoryBar->setCurrentTab( (tab - 1 + n)%n );
140 } 140 }
141} 141}
142 142
143void CategoryTabWidget::nextTab() 143void CategoryTabWidget::nextTab()
144{ 144{
145 if ( categoryBar ) { 145 if ( categoryBar ) {
146 int n = categoryBar->count(); 146 int n = categoryBar->count();
147 int tab = categoryBar->currentTab(); 147 int tab = categoryBar->currentTab();
148 categoryBar->setCurrentTab( (tab + 1)%n ); 148 categoryBar->setCurrentTab( (tab + 1)%n );
149 } 149 }
150} 150}
151 151
152
153void CategoryTabWidget::showTab(const QString& id)
154{
155 if ( categoryBar ) {
156 int idx = ids.findIndex( id );
157 categoryBar->setCurrentTab( idx );
158 }
159}
160
152void CategoryTabWidget::addItem( const QString& linkfile ) 161void CategoryTabWidget::addItem( const QString& linkfile )
153{ 162{
154 int i=0; 163 int i=0;
155 AppLnk *app = new AppLnk(linkfile); 164 AppLnk *app = new AppLnk(linkfile);
156 if ( !app->isValid() ) { 165 if ( !app->isValid() ) {
157 delete app; 166 delete app;
158 app=0; 167 app=0;
159 } 168 }
160 if ( !app || !app->file().isEmpty() ) { 169 if ( !app || !app->file().isEmpty() ) {
161 // A document 170 // A document
162 delete app; 171 delete app;
163 app = new DocLnk(linkfile); 172 app = new DocLnk(linkfile);
164 if ( app->fileKnown() ) { 173 if ( app->fileKnown() ) {
165 ((LauncherView*)(stack->widget(ids.count()-1)))->addItem(app); 174 ((LauncherView*)(stack->widget(ids.count()-1)))->addItem(app);
166 } else { 175 } else {
167 ((LauncherView*)(stack->widget(ids.count()-1)))->sort(); 176 ((LauncherView*)(stack->widget(ids.count()-1)))->sort();
168 delete app; 177 delete app;
169 } 178 }
170 return; 179 return;
171 } 180 }
172 // An application 181 // An application
173 for ( QStringList::Iterator it=ids.begin(); it!=ids.end(); ++it) { 182 for ( QStringList::Iterator it=ids.begin(); it!=ids.end(); ++it) {
174 if ( !(*it).isEmpty() ) { 183 if ( !(*it).isEmpty() ) {
175 QRegExp tf(*it,FALSE,TRUE); 184 QRegExp tf(*it,FALSE,TRUE);
176 if ( tf.match(app->type()) >= 0 ) { 185 if ( tf.match(app->type()) >= 0 ) {
177 ((LauncherView*)stack->widget(i))->addItem(app); 186 ((LauncherView*)stack->widget(i))->addItem(app);
178 return; 187 return;
179 } 188 }
180 i++; 189 i++;
181 } 190 }
182 } 191 }
183 192
184 QCopEnvelope e("QPE/TaskBar","reloadApps()"); 193 QCopEnvelope e("QPE/TaskBar","reloadApps()");
185} 194}
186 195
187void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder, 196void CategoryTabWidget::initializeCategories(AppLnkSet* rootFolder,
188 AppLnkSet* docFolder, const QList<FileSystem> &fs) 197 AppLnkSet* docFolder, const QList<FileSystem> &fs)
189{ 198{
199 QString current;
200 if ( categoryBar ) {
201 int c = categoryBar->currentTab();
202 if ( c >= 0 ) current = ids[c];
203 }
204
190 delete categoryBar; 205 delete categoryBar;
191 categoryBar = new CategoryTabBar( this ); 206 categoryBar = new CategoryTabBar( this );
192 QPalette pal = categoryBar->palette(); 207 QPalette pal = categoryBar->palette();
193 pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) ); 208 pal.setColor( QColorGroup::Light, pal.color(QPalette::Active,QColorGroup::Shadow) );
194 pal.setColor( QColorGroup::Background, pal.active().background().light(110) ); 209 pal.setColor( QColorGroup::Background, pal.active().background().light(110) );
195 categoryBar->setPalette( pal ); 210 categoryBar->setPalette( pal );
196 211
197 delete stack; 212 delete stack;
198 stack = new QWidgetStack(this); 213 stack = new QWidgetStack(this);
199 tabs=0; 214 tabs=0;
200 215
201 ids.clear(); 216 ids.clear();
202 217
203 Config cfg("Launcher"); 218 Config cfg("Launcher");
204 219
205 QStringList types = rootFolder->types(); 220 QStringList types = rootFolder->types();
206 for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) { 221 for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) {
207 if ( !(*it).isEmpty() ) { 222 if ( !(*it).isEmpty() ) {
208 (void)newView(*it,rootFolder->typePixmap(*it),rootFolder->typeName(*it)); 223 (void)newView(*it,rootFolder->typePixmap(*it),rootFolder->typeName(*it));
209 setTabAppearance( *it, cfg ); 224 setTabAppearance( *it, cfg );
210 } 225 }
211 } 226 }
212 QListIterator<AppLnk> it( rootFolder->children() ); 227 QListIterator<AppLnk> it( rootFolder->children() );
213 AppLnk* l; 228 AppLnk* l;
214 while ( (l=it.current()) ) { 229 while ( (l=it.current()) ) {
215 if ( l->type() == "Separator" ) { // No tr 230 if ( l->type() == "Separator" ) { // No tr
216 rootFolder->remove(l); 231 rootFolder->remove(l);
217 delete l; 232 delete l;
218 } else { 233 } else {
219 int i=0; 234 int i=0;
220 for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) { 235 for ( QStringList::Iterator it=types.begin(); it!=types.end(); ++it) {
221 if ( *it == l->type() ) 236 if ( *it == l->type() )
222 ((LauncherView*)stack->widget(i))->addItem(l,FALSE); 237 ((LauncherView*)stack->widget(i))->addItem(l,FALSE);
223 i++; 238 i++;
224 } 239 }
225 } 240 }
226 ++it; 241 ++it;
227 } 242 }
228 rootFolder->detachChildren(); 243 rootFolder->detachChildren();
229 for (int i=0; i<tabs; i++) 244 for (int i=0; i<tabs; i++)
230 ((LauncherView*)stack->widget(i))->sort(); 245 ((LauncherView*)stack->widget(i))->sort();
231 246
232 // all documents 247 // all documents
233 QImage img( Resource::loadImage( "DocsIcon" ) ); 248 QImage img( Resource::loadImage( "DocsIcon" ) );
234 QPixmap pm; 249 QPixmap pm;
235 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() ); 250 pm = img.smoothScale( AppLnk::smallIconSize(), AppLnk::smallIconSize() );
236 docview = newView( "Documents", // No tr 251 docview = newView( "Documents", // No tr
237 pm, tr("Documents")); 252 pm, tr("Documents"));
238 docview->populate( docFolder, QString::null ); 253 docview->populate( docFolder, QString::null );
239 docFolder->detachChildren(); 254 docFolder->detachChildren();
240 docview->setFileSystems(fs); 255 docview->setFileSystems(fs);
241 docview->setToolsEnabled(TRUE); 256 docview->setToolsEnabled(TRUE);
242 setTabAppearance( "Documents", cfg ); // No tr 257 setTabAppearance( "Documents", cfg ); // No tr
243 258
244 connect( categoryBar, SIGNAL(selected(int)), stack, SLOT(raiseWidget(int)) ); 259 connect( categoryBar, SIGNAL(selected(int)), stack, SLOT(raiseWidget(int)) );
245 260
246 ((LauncherView*)stack->widget(0))->setFocus(); 261 ((LauncherView*)stack->widget(0))->setFocus();
247 262
248 cfg. setGroup ( "GUI" ); 263 cfg. setGroup ( "GUI" );
249 setBusyIndicatorType ( cfg. readEntry ( "BusyType", QString::null )); 264 setBusyIndicatorType ( cfg. readEntry ( "BusyType", QString::null ));
250 265
266 if ( !current.isNull() ) {
267 showTab(current);
268 }
269
251 categoryBar->show(); 270 categoryBar->show();
252 stack->show(); 271 stack->show();
272
273 QCopEnvelope e("QPE/TaskBar","reloadApps()");
253} 274}
254 275
255void CategoryTabWidget::setTabAppearance( const QString &id, Config &cfg ) 276void CategoryTabWidget::setTabAppearance( const QString &id, Config &cfg )
256{ 277{
257 QString grp( "Tab %1" ); // No tr 278 QString grp( "Tab %1" ); // No tr
258 cfg.setGroup( grp.arg(id) ); 279 cfg.setGroup( grp.arg(id) );
259 LauncherView *v = view( id ); 280 LauncherView *v = view( id );
260 int idx = ids.findIndex( id ); 281 int idx = ids.findIndex( id );
261 CategoryTab *tab = (CategoryTab *)categoryBar->tab( idx ); 282 CategoryTab *tab = (CategoryTab *)categoryBar->tab( idx );
262 283
263 // View 284 // View
264 QString view = cfg.readEntry( "View", "Icon" ); 285 QString view = cfg.readEntry( "View", "Icon" );
265 if ( view == "List" ) // No tr 286 if ( view == "List" ) // No tr
266 v->setViewMode( LauncherView::List ); 287 v->setViewMode( LauncherView::List );
267 QString bgType = cfg.readEntry( "BackgroundType", "Image" ); 288 QString bgType = cfg.readEntry( "BackgroundType", "Image" );
268 if ( bgType == "Image" ) { // No tr 289 if ( bgType == "Image" ) { // No tr
269 QString pm = cfg.readEntry( "BackgroundImage", "launcher/opie-background" ); 290 QString pm = cfg.readEntry( "BackgroundImage", "launcher/opie-background" );
270 v->setBackgroundType( LauncherView::Image, pm ); 291 v->setBackgroundType( LauncherView::Image, pm );
271 } else if ( bgType == "SolidColor" ) { 292 } else if ( bgType == "SolidColor" ) {
272 QString c = cfg.readEntry( "BackgroundColor" ); 293 QString c = cfg.readEntry( "BackgroundColor" );
273 v->setBackgroundType( LauncherView::SolidColor, c ); 294 v->setBackgroundType( LauncherView::SolidColor, c );
274 } 295 }
275 QString textCol = cfg.readEntry( "TextColor" ); 296 QString textCol = cfg.readEntry( "TextColor" );
276 if ( textCol.isEmpty() ) 297 if ( textCol.isEmpty() )
277 v->setTextColor( QColor() ); 298 v->setTextColor( QColor() );
278 else 299 else
279 v->setTextColor( QColor(textCol) ); 300 v->setTextColor( QColor(textCol) );
280 QStringList font = cfg.readListEntry( "Font", ',' ); 301 QStringList font = cfg.readListEntry( "Font", ',' );
281 if ( font.count() == 4 ) 302 if ( font.count() == 4 )
282 v->setViewFont( QFont(font[0], font[1].toInt(), font[2].toInt(), font[3].toInt()!=0) ); 303 v->setViewFont( QFont(font[0], font[1].toInt(), font[2].toInt(), font[3].toInt()!=0) );
283 304
284 // Tabs 305 // Tabs
285 QString tabCol = cfg.readEntry( "TabColor" ); 306 QString tabCol = cfg.readEntry( "TabColor" );
286 if ( tabCol.isEmpty() ) 307 if ( tabCol.isEmpty() )
287 tab->bgColor = QColor(); 308 tab->bgColor = QColor();
288 else 309 else
289 tab->bgColor = QColor(tabCol); 310 tab->bgColor = QColor(tabCol);
290 QString tabTextCol = cfg.readEntry( "TabTextColor" ); 311 QString tabTextCol = cfg.readEntry( "TabTextColor" );
291 if ( tabTextCol.isEmpty() ) 312 if ( tabTextCol.isEmpty() )
292 tab->fgColor = QColor(); 313 tab->fgColor = QColor();
293 else 314 else
294 tab->fgColor = QColor(tabTextCol); 315 tab->fgColor = QColor(tabTextCol);
295} 316}
296 317
297void CategoryTabWidget::updateDocs(AppLnkSet* docFolder, const QList<FileSystem> &fs) 318void CategoryTabWidget::updateDocs(AppLnkSet* docFolder, const QList<FileSystem> &fs)
298{ 319{
299 docview->populate( docFolder, QString::null ); 320 docview->populate( docFolder, QString::null );
300 docFolder->detachChildren(); 321 docFolder->detachChildren();
301 docview->setFileSystems(fs); 322 docview->setFileSystems(fs);
302 docview->updateTools(); 323 docview->updateTools();
303} 324}
304 325
305void CategoryTabWidget::tabProperties() 326void CategoryTabWidget::tabProperties()
306{ 327{
307 LauncherView *view = (LauncherView*)stack->widget( categoryBar->currentTab() ); 328 LauncherView *view = (LauncherView*)stack->widget( categoryBar->currentTab() );
308 QPopupMenu *m = new QPopupMenu( this ); 329 QPopupMenu *m = new QPopupMenu( this );
309 m->insertItem( tr("Icon View"), LauncherView::Icon ); 330 m->insertItem( tr("Icon View"), LauncherView::Icon );
310 m->insertItem( tr("List View"), LauncherView::List ); 331 m->insertItem( tr("List View"), LauncherView::List );
311 m->setItemChecked( (int)view->viewMode(), TRUE ); 332 m->setItemChecked( (int)view->viewMode(), TRUE );
312 int rv = m->exec( QCursor::pos() ); 333 int rv = m->exec( QCursor::pos() );
313 if ( rv >= 0 && rv != view->viewMode() ) { 334 if ( rv >= 0 && rv != view->viewMode() ) {
314 view->setViewMode( (LauncherView::ViewMode)rv ); 335 view->setViewMode( (LauncherView::ViewMode)rv );
315 } 336 }
316 337
@@ -553,188 +574,188 @@ void CategoryTabBar::paint( QPainter * p, QTab * t, bool selected ) const
553} 574}
554 575
555 576
556void CategoryTabBar::paintLabel( QPainter* p, const QRect&, 577void CategoryTabBar::paintLabel( QPainter* p, const QRect&,
557 QTab* t, bool has_focus ) const 578 QTab* t, bool has_focus ) const
558{ 579{
559 QRect r = t->rect(); 580 QRect r = t->rect();
560 // if ( t->id != currentTab() ) 581 // if ( t->id != currentTab() )
561 //r.moveBy( 1, 1 ); 582 //r.moveBy( 1, 1 );
562 // 583 //
563 if ( t->iconSet() ) { 584 if ( t->iconSet() ) {
564 // the tab has an iconset, draw it in the right mode 585 // the tab has an iconset, draw it in the right mode
565 QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled; 586 QIconSet::Mode mode = (t->isEnabled() && isEnabled()) ? QIconSet::Normal : QIconSet::Disabled;
566 if ( mode == QIconSet::Normal && has_focus ) 587 if ( mode == QIconSet::Normal && has_focus )
567 mode = QIconSet::Active; 588 mode = QIconSet::Active;
568 QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode ); 589 QPixmap pixmap = t->iconSet()->pixmap( QIconSet::Small, mode );
569 int pixw = pixmap.width(); 590 int pixw = pixmap.width();
570 int pixh = pixmap.height(); 591 int pixh = pixmap.height();
571 p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap ); 592 p->drawPixmap( r.left() + 6, r.center().y() - pixh / 2 + 1, pixmap );
572 r.setLeft( r.left() + pixw + 5 ); 593 r.setLeft( r.left() + pixw + 5 );
573 } 594 }
574 595
575 QRect tr = r; 596 QRect tr = r;
576 597
577 if ( r.width() < 20 ) 598 if ( r.width() < 20 )
578 return; 599 return;
579 600
580 if ( t->isEnabled() && isEnabled() ) { 601 if ( t->isEnabled() && isEnabled() ) {
581#if defined(_WS_WIN32_) 602#if defined(_WS_WIN32_)
582 if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) ) 603 if ( colorGroup().brush( QColorGroup::Button ) == colorGroup().brush( QColorGroup::Background ) )
583 p->setPen( colorGroup().buttonText() ); 604 p->setPen( colorGroup().buttonText() );
584 else 605 else
585 p->setPen( colorGroup().foreground() ); 606 p->setPen( colorGroup().foreground() );
586#else 607#else
587 p->setPen( colorGroup().foreground() ); 608 p->setPen( colorGroup().foreground() );
588#endif 609#endif
589 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); 610 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() );
590 } else { 611 } else {
591 p->setPen( palette().disabled().foreground() ); 612 p->setPen( palette().disabled().foreground() );
592 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() ); 613 p->drawText( tr, AlignCenter | AlignVCenter | ShowPrefix, t->text() );
593 } 614 }
594} 615}
595 616
596//--------------------------------------------------------------------------- 617//---------------------------------------------------------------------------
597 618
598Launcher::Launcher( QWidget* parent, const char* name, WFlags fl ) 619Launcher::Launcher( QWidget* parent, const char* name, WFlags fl )
599 : QMainWindow( parent, name, fl ) 620 : QMainWindow( parent, name, fl )
600{ 621{
601 setCaption( tr("Launcher") ); 622 setCaption( tr("Launcher") );
602 623
603 syncDialog = 0; 624 syncDialog = 0;
604 625
605 // we have a pretty good idea how big we'll be 626 // we have a pretty good idea how big we'll be
606 setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() ); 627 setGeometry( 0, 0, qApp->desktop()->width(), qApp->desktop()->height() );
607 628
608 tabs = 0; 629 tabs = 0;
609 rootFolder = 0; 630 rootFolder = 0;
610 docsFolder = 0; 631 docsFolder = 0;
611 632
612 int stamp = uidgen.generate(); // this is our timestamp to see which devices we know 633 int stamp = uidgen.generate(); // this is our timestamp to see which devices we know
613 //uidgen.store( stamp ); 634 //uidgen.store( stamp );
614 m_timeStamp = QString::number( stamp ); 635 m_timeStamp = QString::number( stamp );
615 636
616 tabs = new CategoryTabWidget( this ); 637 tabs = new CategoryTabWidget( this );
617 tabs->setMaximumWidth( qApp->desktop()->width() );
618 setCentralWidget( tabs ); 638 setCentralWidget( tabs );
619 639
620 connect( tabs, SIGNAL(selected(const QString&)), 640 connect( tabs, SIGNAL(selected(const QString&)),
621 this, SLOT(viewSelected(const QString&)) ); 641 this, SLOT(viewSelected(const QString&)) );
622 connect( tabs, SIGNAL(clicked(const AppLnk*)), 642 connect( tabs, SIGNAL(clicked(const AppLnk*)),
623 this, SLOT(select(const AppLnk*))); 643 this, SLOT(select(const AppLnk*)));
624 connect( tabs, SIGNAL(rightPressed(AppLnk*)), 644 connect( tabs, SIGNAL(rightPressed(AppLnk*)),
625 this, SLOT(properties(AppLnk*))); 645 this, SLOT(properties(AppLnk*)));
626 646
627#if !defined(QT_NO_COP) 647#if !defined(QT_NO_COP)
628 QCopChannel* sysChannel = new QCopChannel( "QPE/System", this ); 648 QCopChannel* sysChannel = new QCopChannel( "QPE/System", this );
629 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)), 649 connect( sysChannel, SIGNAL(received(const QCString &, const QByteArray &)),
630 this, SLOT(systemMessage( const QCString &, const QByteArray &)) ); 650 this, SLOT(systemMessage( const QCString &, const QByteArray &)) );
631 QCopChannel *channel = new QCopChannel( "QPE/Launcher", this ); 651 QCopChannel *channel = new QCopChannel( "QPE/Launcher", this );
632 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), 652 connect( channel, SIGNAL(received(const QCString&, const QByteArray&)),
633 this, SLOT(launcherMessage(const QCString&, const QByteArray&)) ); 653 this, SLOT(launcherMessage(const QCString&, const QByteArray&)) );
634#endif 654#endif
635 655
636 storage = new StorageInfo( this ); 656 storage = new StorageInfo( this );
637 connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) ); 657 connect( storage, SIGNAL( disksChanged() ), SLOT( storageChanged() ) );
638 658
639 updateTabs(); 659 updateTabs();
640 660
641 preloadApps(); 661 preloadApps();
642 662
643 in_lnk_props = FALSE; 663 in_lnk_props = FALSE;
644 got_lnk_change = FALSE; 664 got_lnk_change = FALSE;
645} 665}
646 666
647Launcher::~Launcher() 667Launcher::~Launcher()
648{ 668{
649 delete rootFolder; 669 delete rootFolder;
650 delete docsFolder; 670 delete docsFolder;
651} 671}
652 672
653static bool isVisibleWindow(int wid) 673static bool isVisibleWindow(int wid)
654{ 674{
655#ifdef QWS 675#ifdef QWS
656 const QList<QWSWindow> &list = qwsServer->clientWindows(); 676 const QList<QWSWindow> &list = qwsServer->clientWindows();
657 QWSWindow* w; 677 QWSWindow* w;
658 for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) { 678 for (QListIterator<QWSWindow> it(list); (w=it.current()); ++it) {
659 if ( w->winId() == wid ) 679 if ( w->winId() == wid )
660 return !w->isFullyObscured(); 680 return !w->isFullyObscured();
661 } 681 }
662#endif 682#endif
663 return FALSE; 683 return FALSE;
664} 684}
665 685
666void Launcher::showMaximized() 686void Launcher::showMaximized()
667{ 687{
668 if ( isVisibleWindow( winId() ) ) 688 if ( isVisibleWindow( winId() ) )
669 doMaximize(); 689 doMaximize();
670 else 690 else
671 QTimer::singleShot( 20, this, SLOT(doMaximize()) ); 691 QTimer::singleShot( 20, this, SLOT(doMaximize()) );
672} 692}
673 693
674void Launcher::doMaximize() 694void Launcher::doMaximize()
675{ 695{
676 QMainWindow::showMaximized(); 696 QMainWindow::showMaximized();
697 tabs->setMaximumWidth( qApp->desktop()->width() );
677} 698}
678 699
679void Launcher::updateMimeTypes() 700void Launcher::updateMimeTypes()
680{ 701{
681 MimeType::clear(); 702 MimeType::clear();
682 updateMimeTypes(rootFolder); 703 updateMimeTypes(rootFolder);
683} 704}
684 705
685void Launcher::updateMimeTypes(AppLnkSet* folder) 706void Launcher::updateMimeTypes(AppLnkSet* folder)
686{ 707{
687 for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) { 708 for ( QListIterator<AppLnk> it( folder->children() ); it.current(); ++it ) {
688 AppLnk *app = it.current(); 709 AppLnk *app = it.current();
689 if ( app->type() == "Folder" ) // No tr 710 if ( app->type() == "Folder" ) // No tr
690 updateMimeTypes((AppLnkSet *)app); 711 updateMimeTypes((AppLnkSet *)app);
691 else { 712 else {
692 MimeType::registerApp(*app); 713 MimeType::registerApp(*app);
693 } 714 }
694 } 715 }
695} 716}
696 717
697/** This is a HACK.... 718/** This is a HACK....
698 * Reason: scanning huge mediums, microdirvers for examples 719 * Reason: scanning huge mediums, microdirvers for examples
699 * consomes time. To avoid that we invented the MediumMountCheck 720 * consomes time. To avoid that we invented the MediumMountCheck
700 * 721 *
701 * a) the user globally disabled medium checking. We can ignore 722 * a) the user globally disabled medium checking. We can ignore
702 * all removable medium 723 * all removable medium
703 * b) the user enabled medium checking globally and we need to use this mimefilter 724 * b) the user enabled medium checking globally and we need to use this mimefilter
704 * c) the user enabled medium checking on a per medium bases 725 * c) the user enabled medium checking on a per medium bases
705 * c1) we already checked and its not ask again turns 726 * c1) we already checked and its not ask again turns
706 * c2) we need to ask and then apply the mimefilter 727 * c2) we need to ask and then apply the mimefilter
707 */ 728 */
708void Launcher::loadDocs() // ok here comes a hack belonging to Global:: 729void Launcher::loadDocs() // ok here comes a hack belonging to Global::
709{ 730{
710 delete docsFolder; 731 delete docsFolder;
711 docsFolder = new DocLnkSet; 732 docsFolder = new DocLnkSet;
712 733
713 DocLnkSet *tmp = 0; 734 DocLnkSet *tmp = 0;
714 QString home = QString(getenv("HOME")) + "/Documents"; 735 QString home = QString(getenv("HOME")) + "/Documents";
715 tmp = new DocLnkSet( home , QString::null); 736 tmp = new DocLnkSet( home , QString::null);
716 docsFolder->appendFrom( *tmp ); 737 docsFolder->appendFrom( *tmp );
717 delete tmp; 738 delete tmp;
718 739
719 // RAM documents 740 // RAM documents
720 StorageInfo storage; 741 StorageInfo storage;
721 const QList<FileSystem> &fileSystems = storage.fileSystems(); 742 const QList<FileSystem> &fileSystems = storage.fileSystems();
722 QListIterator<FileSystem> it ( fileSystems ); 743 QListIterator<FileSystem> it ( fileSystems );
723 744
724 for ( ; it.current(); ++it ) { 745 for ( ; it.current(); ++it ) {
725 if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) { 746 if ( (*it)->disk() == "/dev/mtdblock6" || (*it)->disk() == "tmpfs" ) {
726 tmp = new DocLnkSet( (*it)->path(), QString::null ); 747 tmp = new DocLnkSet( (*it)->path(), QString::null );
727 docsFolder->appendFrom( *tmp ); 748 docsFolder->appendFrom( *tmp );
728 delete tmp; 749 delete tmp;
729 } 750 }
730 } 751 }
731 752
732 Config mediumCfg( "medium"); 753 Config mediumCfg( "medium");
733 mediumCfg.setGroup("main"); 754 mediumCfg.setGroup("main");
734 // a) -zecke we don't want to check 755 // a) -zecke we don't want to check
735 if(!mediumCfg.readBoolEntry("use", true ) ) 756 if(!mediumCfg.readBoolEntry("use", true ) )
736 return; 757 return;
737 758
738 // find out wich filesystems are new in this round 759 // find out wich filesystems are new in this round
739 // We will do this by having a timestamp inside each mountpoint 760 // We will do this by having a timestamp inside each mountpoint
740 // if the current timestamp doesn't match this is a new file system and 761 // if the current timestamp doesn't match this is a new file system and
@@ -771,186 +792,191 @@ void Launcher::loadDocs() // ok here comes a hack belonging to Global::
771 tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") ); 792 tmp = new DocLnkSet( (*it)->path(), mimetypes.join(";") );
772 docsFolder->appendFrom( *tmp ); 793 docsFolder->appendFrom( *tmp );
773 delete tmp; 794 delete tmp;
774 795
775 }else{ // come up with the gui cause this a new card 796 }else{ // come up with the gui cause this a new card
776 MediumMountGui medium(&cfg, (*it)->path() ); 797 MediumMountGui medium(&cfg, (*it)->path() );
777 if( medium.check() ){ // we did not ask before or ask again is off 798 if( medium.check() ){ // we did not ask before or ask again is off
778 /** c2) */ 799 /** c2) */
779 if( medium.exec() ){ // he clicked yes so search it 800 if( medium.exec() ){ // he clicked yes so search it
780 // speicher 801 // speicher
781 //cfg.read(); // cause of a race we need to reread - fixed 802 //cfg.read(); // cause of a race we need to reread - fixed
782 cfg.setGroup("main"); 803 cfg.setGroup("main");
783 cfg.writeEntry("timestamp", newStamp ); 804 cfg.writeEntry("timestamp", newStamp );
784 cfg.write(); 805 cfg.write();
785 tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) ); 806 tmp = new DocLnkSet( (*it)->path(), medium.mimeTypes().join(";" ) );
786 docsFolder->appendFrom( *tmp ); 807 docsFolder->appendFrom( *tmp );
787 delete tmp; 808 delete tmp;
788 }// no else 809 }// no else
789 /** c1) */ 810 /** c1) */
790 }else{ // we checked 811 }else{ // we checked
791 // do something different see what we need to do 812 // do something different see what we need to do
792 // let's see if we should check the device 813 // let's see if we should check the device
793 cfg.setGroup("main" ); 814 cfg.setGroup("main" );
794 bool check = cfg.readBoolEntry("autocheck", true ); 815 bool check = cfg.readBoolEntry("autocheck", true );
795 if( check ){ // find the documents 816 if( check ){ // find the documents
796 tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") ); 817 tmp = new DocLnkSet( (*it)->path(), configToMime(&cfg ).join(";") );
797 docsFolder->appendFrom( *tmp ); 818 docsFolder->appendFrom( *tmp );
798 delete tmp; 819 delete tmp;
799 } 820 }
800 } 821 }
801 } 822 }
802 } 823 }
803 } 824 }
804 m_timeStamp = newStamp; 825 m_timeStamp = newStamp;
805} 826}
806 827
807void Launcher::updateTabs() 828void Launcher::updateTabs()
808{ 829{
809 MimeType::updateApplications(); // ### reads all applnks twice 830 MimeType::updateApplications(); // ### reads all applnks twice
810 831
811 delete rootFolder; 832 delete rootFolder;
812 rootFolder = new AppLnkSet( MimeType::appsFolderName() ); 833 rootFolder = new AppLnkSet( MimeType::appsFolderName() );
813 834
814 loadDocs(); 835 loadDocs();
815 836
816 tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems()); 837 tabs->initializeCategories(rootFolder, docsFolder, storage->fileSystems());
817} 838}
818 839
819void Launcher::updateDocs() 840void Launcher::updateDocs()
820{ 841{
821 loadDocs(); 842 loadDocs();
822 tabs->updateDocs(docsFolder,storage->fileSystems()); 843 tabs->updateDocs(docsFolder,storage->fileSystems());
823} 844}
824 845
825void Launcher::viewSelected(const QString& s) 846void Launcher::viewSelected(const QString& s)
826{ 847{
827 setCaption( s + tr(" - Launcher") ); 848 setCaption( s + tr(" - Launcher") );
828} 849}
829 850
830void Launcher::nextView() 851void Launcher::nextView()
831{ 852{
832 tabs->nextTab(); 853 tabs->nextTab();
833} 854}
834 855
856void Launcher::showTab(const QString& id)
857{
858 tabs->showTab(id);
859 raise();
860}
835 861
836void Launcher::select( const AppLnk *appLnk ) 862void Launcher::select( const AppLnk *appLnk )
837{ 863{
838 if ( appLnk->type() == "Folder" ) { // No tr 864 if ( appLnk->type() == "Folder" ) { // No tr
839 // Not supported: flat is simpler for the user 865 // Not supported: flat is simpler for the user
840 } else { 866 } else {
841 if ( appLnk->exec().isNull() ) { 867 if ( appLnk->exec().isNull() ) {
842 QMessageBox::information(this,tr("No application"), 868 QMessageBox::information(this,tr("No application"),
843 tr("<p>No application is defined for this document." 869 tr("<p>No application is defined for this document."
844 "<p>Type is %1.").arg(appLnk->type())); 870 "<p>Type is %1.").arg(appLnk->type()));
845 return; 871 return;
846 } 872 }
847 tabs->setBusy(TRUE); 873 tabs->setBusy(TRUE);
848 emit executing( appLnk ); 874 emit executing( appLnk );
849 appLnk->execute(); 875 appLnk->execute();
850 } 876 }
851} 877}
852 878
853void Launcher::externalSelected(const AppLnk *appLnk) 879void Launcher::externalSelected(const AppLnk *appLnk)
854{ 880{
855 tabs->setBusy(TRUE); 881 tabs->setBusy(TRUE);
856 emit executing( appLnk ); 882 emit executing( appLnk );
857} 883}
858 884
859void Launcher::properties( AppLnk *appLnk ) 885void Launcher::properties( AppLnk *appLnk )
860{ 886{
861 if ( appLnk->type() == "Folder" ) { // No tr 887 if ( appLnk->type() == "Folder" ) { // No tr
862 // Not supported: flat is simpler for the user 888 // Not supported: flat is simpler for the user
863 } else { 889 } else {
864 in_lnk_props = TRUE; 890 in_lnk_props = TRUE;
865 got_lnk_change = FALSE; 891 got_lnk_change = FALSE;
866 LnkProperties prop(appLnk); 892 LnkProperties prop(appLnk);
867 connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *))); 893 connect(&prop, SIGNAL(select(const AppLnk *)), this, SLOT(externalSelected(const AppLnk *)));
868 prop.showMaximized(); 894 prop.showMaximized();
869 prop.exec(); 895 prop.exec();
870 in_lnk_props = FALSE; 896 in_lnk_props = FALSE;
871 if ( got_lnk_change ) { 897 if ( got_lnk_change ) {
872 updateLink(lnk_change); 898 updateLink(lnk_change);
873 } 899 }
874 } 900 }
875} 901}
876 902
877void Launcher::updateLink(const QString& link) 903void Launcher::updateLink(const QString& link)
878{ 904{
879 bool notify_sm = false; 905 bool notify_sm = false;
880 906
881 if (link.isNull()) { 907 if (link.isNull()) {
882 updateTabs(); 908 updateTabs();
883 notify_sm = true; 909 notify_sm = true;
884 } 910 }
885 else if (link.isEmpty()) { 911 else if (link.isEmpty()) {
886 updateDocs(); 912 updateDocs();
887 } 913 }
888 else { 914 else {
889 tabs->updateLink(link); 915 tabs->updateLink(link);
890 notify_sm = true; 916 notify_sm = true;
891 } 917 }
892 918
893 if ( notify_sm ) 919 if ( notify_sm )
894 QCopEnvelope e ( "QPE/TaskBar", "reloadApps()" ); 920 QCopEnvelope e ( "QPE/TaskBar", "reloadApps()" );
895} 921}
896 922
897void Launcher::systemMessage( const QCString &msg, const QByteArray &data) 923void Launcher::systemMessage( const QCString &msg, const QByteArray &data)
898{ 924{
899 QDataStream stream( data, IO_ReadOnly ); 925 QDataStream stream( data, IO_ReadOnly );
900 if ( msg == "linkChanged(QString)" ) { 926 if ( msg == "linkChanged(QString)" ) {
901 QString link; 927 QString link;
902 stream >> link; 928 stream >> link;
903 if ( in_lnk_props ) { 929 if ( in_lnk_props ) {
904 got_lnk_change = TRUE; 930 got_lnk_change = TRUE;
905 lnk_change = link; 931 lnk_change = link;
906 } else { 932 } else {
907 updateLink(link); 933 updateLink(link);
908 } 934 }
909 } else if ( msg == "busy()" ) { 935 } else if ( msg == "busy()" ) {
910 emit busy(); 936 emit busy();
911 } else if ( msg == "notBusy(QString)" ) { 937 } else if ( msg == "notBusy(QString)" ) {
912 QString app; 938 QString app;
913 stream >> app; 939 stream >> app;
914 tabs->setBusy(FALSE); 940 tabs->setBusy(FALSE);
915 emit notBusy(app); 941 emit notBusy(app);
916 } else if ( msg == "mkdir(QString)" ) { 942 } else if ( msg == "mkdir(QString)" ) {
917 QString dir; 943 QString dir;
918 stream >> dir; 944 stream >> dir;
919 if ( !dir.isEmpty() ) 945 if ( !dir.isEmpty() )
920 mkdir( dir ); 946 mkdir( dir );
921 } else if ( msg == "rdiffGenSig(QString,QString)" ) { 947 } else if ( msg == "rdiffGenSig(QString,QString)" ) {
922 QString baseFile, sigFile; 948 QString baseFile, sigFile;
923 stream >> baseFile >> sigFile; 949 stream >> baseFile >> sigFile;
924 QRsync::generateSignature( baseFile, sigFile ); 950 QRsync::generateSignature( baseFile, sigFile );
925 } else if ( msg == "rdiffGenDiff(QString,QString,QString)" ) { 951 } else if ( msg == "rdiffGenDiff(QString,QString,QString)" ) {
926 QString baseFile, sigFile, deltaFile; 952 QString baseFile, sigFile, deltaFile;
927 stream >> baseFile >> sigFile >> deltaFile; 953 stream >> baseFile >> sigFile >> deltaFile;
928 QRsync::generateDiff( baseFile, sigFile, deltaFile ); 954 QRsync::generateDiff( baseFile, sigFile, deltaFile );
929 } else if ( msg == "rdiffApplyPatch(QString,QString)" ) { 955 } else if ( msg == "rdiffApplyPatch(QString,QString)" ) {
930 QString baseFile, deltaFile; 956 QString baseFile, deltaFile;
931 stream >> baseFile >> deltaFile; 957 stream >> baseFile >> deltaFile;
932 if ( !QFile::exists( baseFile ) ) { 958 if ( !QFile::exists( baseFile ) ) {
933 QFile f( baseFile ); 959 QFile f( baseFile );
934 f.open( IO_WriteOnly ); 960 f.open( IO_WriteOnly );
935 f.close(); 961 f.close();
936 } 962 }
937 QRsync::applyDiff( baseFile, deltaFile ); 963 QRsync::applyDiff( baseFile, deltaFile );
938#ifndef QT_NO_COP 964#ifndef QT_NO_COP
939 QCopEnvelope e( "QPE/Desktop", "patchApplied(QString)" ); 965 QCopEnvelope e( "QPE/Desktop", "patchApplied(QString)" );
940 e << baseFile; 966 e << baseFile;
941#endif 967#endif
942 } else if ( msg == "rdiffCleanup()" ) { 968 } else if ( msg == "rdiffCleanup()" ) {
943 mkdir( "/tmp/rdiff" ); 969 mkdir( "/tmp/rdiff" );
944 QDir dir; 970 QDir dir;
945 dir.setPath( "/tmp/rdiff" ); 971 dir.setPath( "/tmp/rdiff" );
946 QStringList entries = dir.entryList(); 972 QStringList entries = dir.entryList();
947 for ( QStringList::Iterator it = entries.begin(); it != entries.end(); ++it ) 973 for ( QStringList::Iterator it = entries.begin(); it != entries.end(); ++it )
948 dir.remove( *it ); 974 dir.remove( *it );
949 } else if ( msg == "sendHandshakeInfo()" ) { 975 } else if ( msg == "sendHandshakeInfo()" ) {
950 QString home = getenv( "HOME" ); 976 QString home = getenv( "HOME" );
951#ifndef QT_NO_COP 977#ifndef QT_NO_COP
952 QCopEnvelope e( "QPE/Desktop", "handshakeInfo(QString,bool)" ); 978 QCopEnvelope e( "QPE/Desktop", "handshakeInfo(QString,bool)" );
953 e << home; 979 e << home;
954 int locked = (int) Desktop::screenLocked(); 980 int locked = (int) Desktop::screenLocked();
955 e << locked; 981 e << locked;
956#endif 982#endif
@@ -1128,137 +1154,137 @@ void Launcher::systemMessage( const QCString &msg, const QByteArray &data)
1128 setenv("QWS_MOUSE_PROTO",mice.latin1(),1); 1154 setenv("QWS_MOUSE_PROTO",mice.latin1(),1);
1129 qwsServer->openMouse(); 1155 qwsServer->openMouse();
1130 } else if ( msg == "setKeyboard(QString)" ) { 1156 } else if ( msg == "setKeyboard(QString)" ) {
1131 QString kb; 1157 QString kb;
1132 stream >> kb; 1158 stream >> kb;
1133 setenv("QWS_KEYBOARD",kb.latin1(),1); 1159 setenv("QWS_KEYBOARD",kb.latin1(),1);
1134 qwsServer->openKeyboard(); 1160 qwsServer->openKeyboard();
1135#endif 1161#endif
1136 } 1162 }
1137} 1163}
1138 1164
1139void Launcher::cancelSync() 1165void Launcher::cancelSync()
1140{ 1166{
1141#ifndef QT_NO_COP 1167#ifndef QT_NO_COP
1142 QCopEnvelope e( "QPE/Desktop", "cancelSync()" ); 1168 QCopEnvelope e( "QPE/Desktop", "cancelSync()" );
1143#endif 1169#endif
1144} 1170}
1145 1171
1146void Launcher::launcherMessage( const QCString &msg, const QByteArray &data) 1172void Launcher::launcherMessage( const QCString &msg, const QByteArray &data)
1147{ 1173{
1148 QDataStream stream( data, IO_ReadOnly ); 1174 QDataStream stream( data, IO_ReadOnly );
1149 if ( msg == "setTabView(QString,int)" ) { 1175 if ( msg == "setTabView(QString,int)" ) {
1150 QString id; 1176 QString id;
1151 stream >> id; 1177 stream >> id;
1152 int mode; 1178 int mode;
1153 stream >> mode; 1179 stream >> mode;
1154 if ( tabs->view(id) ) 1180 if ( tabs->view(id) )
1155 tabs->view(id)->setViewMode( (LauncherView::ViewMode)mode ); 1181 tabs->view(id)->setViewMode( (LauncherView::ViewMode)mode );
1156 } else if ( msg == "setTabBackground(QString,int,QString)" ) { 1182 } else if ( msg == "setTabBackground(QString,int,QString)" ) {
1157 QString id; 1183 QString id;
1158 stream >> id; 1184 stream >> id;
1159 int mode; 1185 int mode;
1160 stream >> mode; 1186 stream >> mode;
1161 QString pixmapOrColor; 1187 QString pixmapOrColor;
1162 stream >> pixmapOrColor; 1188 stream >> pixmapOrColor;
1163 if ( tabs->view(id) ) 1189 if ( tabs->view(id) )
1164 tabs->view(id)->setBackgroundType( (LauncherView::BackgroundType)mode, pixmapOrColor ); 1190 tabs->view(id)->setBackgroundType( (LauncherView::BackgroundType)mode, pixmapOrColor );
1165 } else if ( msg == "setTextColor(QString,QString)" ) { 1191 } else if ( msg == "setTextColor(QString,QString)" ) {
1166 QString id; 1192 QString id;
1167 stream >> id; 1193 stream >> id;
1168 QString color; 1194 QString color;
1169 stream >> color; 1195 stream >> color;
1170 if ( tabs->view(id) ) 1196 if ( tabs->view(id) )
1171 tabs->view(id)->setTextColor( QColor(color) ); 1197 tabs->view(id)->setTextColor( QColor(color) );
1172 } else if ( msg == "setFont(QString,QString,int,int,int)" ) { 1198 } else if ( msg == "setFont(QString,QString,int,int,int)" ) {
1173 QString id; 1199 QString id;
1174 stream >> id; 1200 stream >> id;
1175 QString fam; 1201 QString fam;
1176 stream >> fam; 1202 stream >> fam;
1177 int size; 1203 int size;
1178 stream >> size; 1204 stream >> size;
1179 int weight; 1205 int weight;
1180 stream >> weight; 1206 stream >> weight;
1181 int italic; 1207 int italic;
1182 stream >> italic; 1208 stream >> italic;
1183 if ( tabs->view(id) ) 1209 if ( tabs->view(id) )
1184 if ( !fam. isEmpty ( )) 1210 if ( !fam. isEmpty ( ))
1185 tabs->view(id)->setViewFont( QFont(fam, size, weight, italic!=0) ); 1211 tabs->view(id)->setViewFont( QFont(fam, size, weight, italic!=0) );
1186 else 1212 else
1187 tabs->view(id)->unsetViewFont(); 1213 tabs->view(id)->unsetViewFont();
1188 qDebug( "setFont: %s, %d, %d, %d", fam.latin1(), size, weight, italic ); 1214 qDebug( "setFont: %s, %d, %d, %d", fam.latin1(), size, weight, italic );
1189 } 1215 }
1190 else if ( msg == "setBusyIndicatorType(QString)" ) { 1216 else if ( msg == "setBusyIndicatorType(QString)" ) {
1191 QString type; 1217 QString type;
1192 stream >> type; 1218 stream >> type;
1193 tabs->setBusyIndicatorType(type); 1219 tabs->setBusyIndicatorType(type);
1194 } 1220 }
1195 else if ( msg == "home()" ) { 1221 else if ( msg == "home()" ) {
1196 if ( isVisibleWindow( winId ( ))) 1222 if ( isVisibleWindow( winId ( )))
1197 nextView ( ); 1223 nextView ( );
1198 else 1224 else
1199 raise ( ); 1225 raise ( );
1200 1226
1201 } 1227 }
1202} 1228}
1203 1229
1204void Launcher::storageChanged() 1230void Launcher::storageChanged()
1205{ 1231{
1206 if ( in_lnk_props ) { 1232 if ( in_lnk_props ) {
1207 got_lnk_change = TRUE; 1233 got_lnk_change = TRUE;
1208 lnk_change = QString::null; 1234 lnk_change = QString::null;
1209 } else { 1235 } else {
1210 updateLink( QString::null ); 1236 updateLink( QString::null );
1211 } 1237 }
1212} 1238}
1213 1239
1214 1240
1215bool Launcher::mkdir(const QString &localPath) 1241bool Launcher::mkdir(const QString &localPath)
1216{ 1242{
1217 QDir fullDir(localPath); 1243 QDir fullDir(localPath);
1218 if (fullDir.exists()) 1244 if (fullDir.exists())
1219 return true; 1245 return true;
1220 1246
1221 // at this point the directory doesn't exist 1247 // at this point the directory doesn't exist
1222 // go through the directory tree and start creating the direcotories 1248 // go through the directory tree and start creating the direcotories
1223 // that don't exist; if we can't create the directories, return false 1249 // that don't exist; if we can't create the directories, return false
1224 1250
1225 QString dirSeps = "/"; 1251 QString dirSeps = "/";
1226 int dirIndex = localPath.find(dirSeps); 1252 int dirIndex = localPath.find(dirSeps);
1227 QString checkedPath; 1253 QString checkedPath;
1228 1254
1229 // didn't find any seps; weird, use the cur dir instead 1255 // didn't find any seps; weird, use the cur dir instead
1230 if (dirIndex == -1) { 1256 if (dirIndex == -1) {
1231 //qDebug("No seperators found in path %s", localPath.latin1()); 1257 //qDebug("No seperators found in path %s", localPath.latin1());
1232 checkedPath = QDir::currentDirPath(); 1258 checkedPath = QDir::currentDirPath();
1233 } 1259 }
1234 1260
1235 while (checkedPath != localPath) { 1261 while (checkedPath != localPath) {
1236 // no more seperators found, use the local path 1262 // no more seperators found, use the local path
1237 if (dirIndex == -1) 1263 if (dirIndex == -1)
1238 checkedPath = localPath; 1264 checkedPath = localPath;
1239 else { 1265 else {
1240 // the next directory to check 1266 // the next directory to check
1241 checkedPath = localPath.left(dirIndex) + "/"; 1267 checkedPath = localPath.left(dirIndex) + "/";
1242 // advance the iterator; the next dir seperator 1268 // advance the iterator; the next dir seperator
1243 dirIndex = localPath.find(dirSeps, dirIndex+1); 1269 dirIndex = localPath.find(dirSeps, dirIndex+1);
1244 } 1270 }
1245 1271
1246 QDir checkDir(checkedPath); 1272 QDir checkDir(checkedPath);
1247 if (!checkDir.exists()) { 1273 if (!checkDir.exists()) {
1248 //qDebug("mkdir making dir %s", checkedPath.latin1()); 1274 //qDebug("mkdir making dir %s", checkedPath.latin1());
1249 1275
1250 if (!checkDir.mkdir(checkedPath)) { 1276 if (!checkDir.mkdir(checkedPath)) {
1251 qDebug("Unable to make directory %s", checkedPath.latin1()); 1277 qDebug("Unable to make directory %s", checkedPath.latin1());
1252 return FALSE; 1278 return FALSE;
1253 } 1279 }
1254 } 1280 }
1255 1281
1256 } 1282 }
1257 return TRUE; 1283 return TRUE;
1258} 1284}
1259 1285
1260void Launcher::preloadApps() 1286void Launcher::preloadApps()
1261{ 1287{
1262 Config cfg("Launcher"); 1288 Config cfg("Launcher");
1263 cfg.setGroup("Preload"); 1289 cfg.setGroup("Preload");
1264 QStringList apps = cfg.readListEntry("Apps",','); 1290 QStringList apps = cfg.readListEntry("Apps",',');
diff --git a/core/launcher/launcher.h b/core/launcher/launcher.h
index 89bf6f3..c92ef5d 100644
--- a/core/launcher/launcher.h
+++ b/core/launcher/launcher.h
@@ -11,139 +11,141 @@
11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 11** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 12** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
13** 13**
14** See http://www.trolltech.com/gpl/ for GPL licensing information. 14** See http://www.trolltech.com/gpl/ for GPL licensing information.
15** 15**
16** Contact info@trolltech.com if any conditions of this licensing are 16** Contact info@trolltech.com if any conditions of this licensing are
17** not clear to you. 17** not clear to you.
18** 18**
19**********************************************************************/ 19**********************************************************************/
20#ifndef LAUNCHER_H 20#ifndef LAUNCHER_H
21#define LAUNCHER_H 21#define LAUNCHER_H
22 22
23#include <qpe/config.h> 23#include <qpe/config.h>
24#include <qmainwindow.h> 24#include <qmainwindow.h>
25#include <qtabbar.h> 25#include <qtabbar.h>
26#include <qstringlist.h> 26#include <qstringlist.h>
27#include <qvbox.h> 27#include <qvbox.h>
28#include <qlist.h> 28#include <qlist.h>
29#include <qpe/palmtopuidgen.h> 29#include <qpe/palmtopuidgen.h>
30#include "launcherview.h" 30#include "launcherview.h"
31 31
32class AppLnk; 32class AppLnk;
33class AppLnkSet; 33class AppLnkSet;
34class DocLnkSet; 34class DocLnkSet;
35class QWidgetStack; 35class QWidgetStack;
36class StorageInfo; 36class StorageInfo;
37class SyncDialog; 37class SyncDialog;
38 38
39class CategoryTabBar : public QTabBar 39class CategoryTabBar : public QTabBar
40{ 40{
41 Q_OBJECT 41 Q_OBJECT
42public: 42public:
43 CategoryTabBar( QWidget *parent=0, const char *name=0 ); 43 CategoryTabBar( QWidget *parent=0, const char *name=0 );
44 ~CategoryTabBar(); 44 ~CategoryTabBar();
45 45
46protected slots: 46protected slots:
47 virtual void layoutTabs(); 47 virtual void layoutTabs();
48 48
49protected: 49protected:
50 void paint ( QPainter *p, QTab *t, bool f ) const; 50 void paint ( QPainter *p, QTab *t, bool f ) const;
51 void paintLabel( QPainter* p, const QRect& br, QTab* t, bool has_focus ) const; 51 void paintLabel( QPainter* p, const QRect& br, QTab* t, bool has_focus ) const;
52}; 52};
53 53
54class CategoryTabWidget : public QVBox { 54class CategoryTabWidget : public QVBox {
55 // can't use a QTabWidget, since it won't let us set the frame style. 55 // can't use a QTabWidget, since it won't let us set the frame style.
56 Q_OBJECT 56 Q_OBJECT
57public: 57public:
58 CategoryTabWidget( QWidget* parent ); 58 CategoryTabWidget( QWidget* parent );
59 void initializeCategories(AppLnkSet* rootFolder, AppLnkSet* docFolder, 59 void initializeCategories(AppLnkSet* rootFolder, AppLnkSet* docFolder,
60 const QList<FileSystem> &); 60 const QList<FileSystem> &);
61 void updateDocs(AppLnkSet* docFolder, const QList<FileSystem> &fs); 61 void updateDocs(AppLnkSet* docFolder, const QList<FileSystem> &fs);
62 void updateLink(const QString& linkfile); 62 void updateLink(const QString& linkfile);
63 void setBusy(bool on); 63 void setBusy(bool on);
64 QString getAllDocLinkInfo() const; 64 QString getAllDocLinkInfo() const;
65 LauncherView *view( const QString &id ); 65 LauncherView *view( const QString &id );
66 void setBusyIndicatorType ( const QString &type ); 66 void setBusyIndicatorType ( const QString &type );
67signals: 67signals:
68 void selected(const QString&); 68 void selected(const QString&);
69 void clicked(const AppLnk*); 69 void clicked(const AppLnk*);
70 void rightPressed(AppLnk*); 70 void rightPressed(AppLnk*);
71 71
72public slots: 72public slots:
73 void nextTab(); 73 void nextTab();
74 void prevTab(); 74 void prevTab();
75 void showTab(const QString&);
75 76
76protected slots: 77protected slots:
77 void tabProperties(); 78 void tabProperties();
78 79
79protected: 80protected:
80 void setTabAppearance( const QString &id, Config &cfg ); 81 void setTabAppearance( const QString &id, Config &cfg );
81 void paletteChange( const QPalette &p ); 82 void paletteChange( const QPalette &p );
82 83
83private: 84private:
84 CategoryTabBar* categoryBar; 85 CategoryTabBar* categoryBar;
85 QWidgetStack* stack; 86 QWidgetStack* stack;
86 LauncherView* docview; 87 LauncherView* docview;
87 QStringList ids; 88 QStringList ids;
88 int tabs; 89 int tabs;
89 LauncherView* newView( const QString&, const QPixmap& pm, const QString& label ); 90 LauncherView* newView( const QString&, const QPixmap& pm, const QString& label );
90 void addItem( const QString& ); 91 void addItem( const QString& );
91}; 92};
92 93
93class Launcher : public QMainWindow 94class Launcher : public QMainWindow
94{ 95{
95 Q_OBJECT 96 Q_OBJECT
96 friend class LauncherPrivate; 97 friend class LauncherPrivate;
97public: 98public:
98 Launcher( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 ); 99 Launcher( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
99 ~Launcher(); 100 ~Launcher();
100 101
101 static QString appsFolderName(); 102 static QString appsFolderName();
102 103
103 virtual void showMaximized(); 104 virtual void showMaximized();
104 static bool mkdir(const QString &path); 105 static bool mkdir(const QString &path);
105 106
106public slots: 107public slots:
107 void viewSelected(const QString&); 108 void viewSelected(const QString&);
109 void showTab(const QString&);
108 void select( const AppLnk * ); 110 void select( const AppLnk * );
109 void externalSelected( const AppLnk *); 111 void externalSelected( const AppLnk *);
110 void properties( AppLnk * ); 112 void properties( AppLnk * );
111 void nextView(); 113 void nextView();
112 114
113signals: 115signals:
114 void executing( const AppLnk * ); 116 void executing( const AppLnk * );
115 void busy(); 117 void busy();
116 void notBusy(const QString&); 118 void notBusy(const QString&);
117 119
118private slots: 120private slots:
119 void doMaximize(); 121 void doMaximize();
120 void systemMessage( const QCString &, const QByteArray &); 122 void systemMessage( const QCString &, const QByteArray &);
121 void launcherMessage( const QCString &, const QByteArray &); 123 void launcherMessage( const QCString &, const QByteArray &);
122 void storageChanged(); 124 void storageChanged();
123 void cancelSync(); 125 void cancelSync();
124 126
125private: 127private:
126 void updateApps(); 128 void updateApps();
127 void loadDocs(); 129 void loadDocs();
128 void updateDocs(); 130 void updateDocs();
129 void updateTabs(); 131 void updateTabs();
130 void updateMimeTypes(); 132 void updateMimeTypes();
131 void updateMimeTypes(AppLnkSet*); 133 void updateMimeTypes(AppLnkSet*);
132 void preloadApps(); 134 void preloadApps();
133 AppLnkSet *rootFolder; 135 AppLnkSet *rootFolder;
134 DocLnkSet *docsFolder; 136 DocLnkSet *docsFolder;
135 CategoryTabWidget *tabs; 137 CategoryTabWidget *tabs;
136 StorageInfo *storage; 138 StorageInfo *storage;
137 SyncDialog *syncDialog; 139 SyncDialog *syncDialog;
138 140
139 void updateLink(const QString& link); 141 void updateLink(const QString& link);
140 bool in_lnk_props; 142 bool in_lnk_props;
141 bool got_lnk_change; 143 bool got_lnk_change;
142 QString lnk_change; 144 QString lnk_change;
143 145
144 QString m_timeStamp; 146 QString m_timeStamp;
145 Qtopia::UidGen uidgen; 147 Qtopia::UidGen uidgen;
146}; 148};
147 149
148#endif // LAUNCHERVIEW_H 150#endif // LAUNCHERVIEW_H
149 151