-rw-r--r-- | core/launcher/launcher.cpp | 18 | ||||
-rw-r--r-- | core/launcher/launcherview.cpp | 127 | ||||
-rw-r--r-- | core/launcher/launcherview.h | 1 |
3 files changed, 70 insertions, 76 deletions
diff --git a/core/launcher/launcher.cpp b/core/launcher/launcher.cpp index 010a2e9..5ec1cf8 100644 --- a/core/launcher/launcher.cpp +++ b/core/launcher/launcher.cpp | |||
@@ -352,22 +352,22 @@ void LauncherTabWidget::setProgressStyle() | |||
352 | */ | 352 | */ |
353 | 353 | ||
354 | void LauncherTabWidget::setBusy(bool on) | 354 | void LauncherTabWidget::setBusy(bool on) |
355 | { | 355 | { |
356 | if ( on ) | 356 | if ( on ) |
357 | currentView()->setBusy(TRUE); | 357 | currentView()->setBusy(TRUE); |
358 | else { | 358 | else { |
359 | for ( int i = 0; i < categoryBar->count(); i++ ) { | 359 | for ( int i = 0; i < categoryBar->count(); i++ ) { |
360 | if (categoryBar->tab(i)) { | 360 | if (categoryBar->tab(i)) { |
361 | LauncherView *view = ((LauncherTab *)categoryBar->tab(i))->view; | 361 | LauncherView *view = ((LauncherTab *)categoryBar->tab(i))->view; |
362 | view->setBusy( FALSE ); | 362 | view->setBusy( FALSE ); |
363 | } else { | 363 | } else { |
364 | odebug << "Averting Disaster with tab " << i << " == NULL! " << oendl; | 364 | odebug << "Averting Disaster with tab " << i << " == NULL! " << oendl; |
365 | } | 365 | } |
366 | } | 366 | } |
367 | } | 367 | } |
368 | } | 368 | } |
369 | 369 | ||
370 | void LauncherTabWidget::setBusyIndicatorType( const QString& str ) { | 370 | void LauncherTabWidget::setBusyIndicatorType( const QString& str ) { |
371 | for (int i = 0; i < categoryBar->count(); i++ ) { | 371 | for (int i = 0; i < categoryBar->count(); i++ ) { |
372 | LauncherView* view = static_cast<LauncherTab*>( categoryBar->tab(i) )->view; | 372 | LauncherView* view = static_cast<LauncherTab*>( categoryBar->tab(i) )->view; |
373 | view->setBusyIndicatorType( str ); | 373 | view->setBusyIndicatorType( str ); |
@@ -596,19 +596,21 @@ void Launcher::select( const AppLnk *appLnk ) | |||
596 | } | 596 | } |
597 | 597 | ||
598 | void Launcher::properties( AppLnk *appLnk ) | 598 | void Launcher::properties( AppLnk *appLnk ) |
599 | { | 599 | { |
600 | if ( appLnk->type() == "Folder" ) { // No tr | 600 | if ( appLnk->type() == "Folder" ) { // No tr |
601 | // Not supported: flat is simpler for the user | 601 | // Not supported: flat is simpler for the user |
602 | } else { | 602 | } else { |
603 | /* ### libqtopia FIXME also moving docLnks... */ | 603 | /* ### libqtopia FIXME also moving docLnks... */ |
604 | LnkProperties prop(appLnk,0 ); | 604 | LnkProperties prop(appLnk,0 ); |
605 | 605 | ||
606 | QPEApplication::execDialog( &prop ); | 606 | if (QPEApplication::execDialog( &prop )==QDialog::Accepted && tabs->currentView()==tabs->docView()) { |
607 | tabs->docView()->updateTools(); | ||
608 | } | ||
607 | } | 609 | } |
608 | } | 610 | } |
609 | 611 | ||
610 | void Launcher::storageChanged( const QList<FileSystem> & ) | 612 | void Launcher::storageChanged( const QList<FileSystem> & ) |
611 | { | 613 | { |
612 | // ### update combo boxes if we had a combo box for the storage type | 614 | // ### update combo boxes if we had a combo box for the storage type |
613 | } | 615 | } |
614 | 616 | ||
diff --git a/core/launcher/launcherview.cpp b/core/launcher/launcherview.cpp index 72313e3..ff26133 100644 --- a/core/launcher/launcherview.cpp +++ b/core/launcher/launcherview.cpp | |||
@@ -126,17 +126,17 @@ LauncherItem::LauncherItem( QIconView *parent, AppLnk *applnk, bool bigIcon ) | |||
126 | m_iPixmap = (bigIcon ? applnk->bigPixmap():applnk->pixmap()); | 126 | m_iPixmap = (bigIcon ? applnk->bigPixmap():applnk->pixmap()); |
127 | } | 127 | } |
128 | } | 128 | } |
129 | 129 | ||
130 | LauncherItem::~LauncherItem() | 130 | LauncherItem::~LauncherItem() |
131 | { | 131 | { |
132 | LauncherIconView* liv = (LauncherIconView*)iconView(); | 132 | LauncherIconView* liv = (LauncherIconView*)iconView(); |
133 | if ( liv->busyItem() == this ) | 133 | if ( liv->busyItem() == this ) |
134 | liv->setBusy(FALSE); | 134 | liv->setBusy(FALSE); |
135 | delete app; | 135 | delete app; |
136 | } | 136 | } |
137 | 137 | ||
138 | QPixmap*LauncherItem::pixmap()const | 138 | QPixmap*LauncherItem::pixmap()const |
139 | { | 139 | { |
140 | if (m_EyeImage && m_EyeImageSet == BASE_ICON) { | 140 | if (m_EyeImage && m_EyeImageSet == BASE_ICON) { |
141 | LauncherIconView* liv = (LauncherIconView*)iconView(); | 141 | LauncherIconView* liv = (LauncherIconView*)iconView(); |
142 | liv->requestEyePix(this); | 142 | liv->requestEyePix(this); |
@@ -271,16 +271,17 @@ LauncherIconView::LauncherIconView( QWidget* parent, const char* name ) | |||
271 | hidden.setAutoDelete(TRUE); | 271 | hidden.setAutoDelete(TRUE); |
272 | ike = FALSE; | 272 | ike = FALSE; |
273 | calculateGrid( Bottom ); | 273 | calculateGrid( Bottom ); |
274 | connect(&m_eyeTimer,SIGNAL(timeout()),this,SLOT(stopEyeTimer())); | 274 | connect(&m_eyeTimer,SIGNAL(timeout()),this,SLOT(stopEyeTimer())); |
275 | } | 275 | } |
276 | 276 | ||
277 | LauncherIconView::~LauncherIconView() | 277 | LauncherIconView::~LauncherIconView() |
278 | { | 278 | { |
279 | odebug << "LauncherIconView::~LauncherIconView()" << oendl; | ||
279 | #if 0 // debuggery | 280 | #if 0 // debuggery |
280 | QListIterator<AppLnk> it(hidden); | 281 | QListIterator<AppLnk> it(hidden); |
281 | AppLnk* l; | 282 | AppLnk* l; |
282 | while ((l=it.current())) { | 283 | while ((l=it.current())) { |
283 | ++it; | 284 | ++it; |
284 | //odebug << "" << l << ": hidden (should remove)" << oendl; | 285 | //odebug << "" << l << ": hidden (should remove)" << oendl; |
285 | } | 286 | } |
286 | #endif | 287 | #endif |
@@ -424,24 +425,17 @@ LauncherItem*LauncherIconView::findDocItem(const QString&fname) | |||
424 | } | 425 | } |
425 | return item; | 426 | return item; |
426 | } | 427 | } |
427 | 428 | ||
428 | void LauncherIconView::setEyePixmap(const QPixmap&aPixmap,const QString&aFile,int width) | 429 | void LauncherIconView::setEyePixmap(const QPixmap&aPixmap,const QString&aFile,int width) |
429 | { | 430 | { |
430 | int s = ( bigIcns ) ? AppLnk::bigIconSize() : AppLnk::smallIconSize(); | 431 | int s = ( bigIcns ) ? AppLnk::bigIconSize() : AppLnk::smallIconSize(); |
431 | if (s!=width) return; | 432 | if (s!=width) return; |
432 | LauncherItem*item = 0; | 433 | LauncherItem*item = findDocItem(aFile); |
433 | QMap<QString,LauncherItem*>::Iterator it; | ||
434 | if ( ( it = m_itemCache.find(aFile))!=m_itemCache.end()) { | ||
435 | item = it.data(); | ||
436 | m_itemCache.remove(it); | ||
437 | } else { | ||
438 | item = findDocItem(aFile); | ||
439 | } | ||
440 | if (!item||!item->isEyeImage()) return; | 434 | if (!item||!item->isEyeImage()) return; |
441 | item->setEyePixmap(aPixmap); | 435 | item->setEyePixmap(aPixmap); |
442 | } | 436 | } |
443 | 437 | ||
444 | void LauncherIconView::checkCallback() | 438 | void LauncherIconView::checkCallback() |
445 | { | 439 | { |
446 | if (!m_EyeCallBack) { | 440 | if (!m_EyeCallBack) { |
447 | m_EyeCallBack = new LauncherThumbReceiver(); | 441 | m_EyeCallBack = new LauncherThumbReceiver(); |
@@ -460,28 +454,26 @@ void LauncherIconView::addCheckItem(AppLnk* app) | |||
460 | } | 454 | } |
461 | 455 | ||
462 | void LauncherIconView::requestEyePix(const LauncherItem*item) | 456 | void LauncherIconView::requestEyePix(const LauncherItem*item) |
463 | { | 457 | { |
464 | if (!item) return; | 458 | if (!item) return; |
465 | if (item->isEyeImage()) { | 459 | if (item->isEyeImage()) { |
466 | checkCallback(); | 460 | checkCallback(); |
467 | int s = ( bigIcns ) ? AppLnk::bigIconSize() : AppLnk::smallIconSize(); | 461 | int s = ( bigIcns ) ? AppLnk::bigIconSize() : AppLnk::smallIconSize(); |
468 | m_itemCache[item->appLnk()->file()]=(LauncherItem*)item; | ||
469 | m_EyeCallBack->requestThumb(item->appLnk()->file(),s,s); | 462 | m_EyeCallBack->requestThumb(item->appLnk()->file(),s,s); |
470 | } | 463 | } |
471 | } | 464 | } |
472 | 465 | ||
473 | void LauncherIconView::stopEyeTimer() | 466 | void LauncherIconView::stopEyeTimer() |
474 | { | 467 | { |
475 | if (m_EyeCallBack) { | 468 | if (m_EyeCallBack) { |
476 | delete m_EyeCallBack; | 469 | delete m_EyeCallBack; |
477 | m_EyeCallBack=0; | 470 | m_EyeCallBack=0; |
478 | } | 471 | } |
479 | m_itemCache.clear(); | ||
480 | m_eyeTimer.stop(); | 472 | m_eyeTimer.stop(); |
481 | } | 473 | } |
482 | 474 | ||
483 | void LauncherIconView::addItem(AppLnk* app, bool resort) | 475 | void LauncherIconView::addItem(AppLnk* app, bool resort) |
484 | { | 476 | { |
485 | addCatsAndMimes(app); | 477 | addCatsAndMimes(app); |
486 | if ( (tf.isEmpty() || tf.match(app->type()) >= 0) | 478 | if ( (tf.isEmpty() || tf.match(app->type()) >= 0) |
487 | && (cf == 0 || app->categories().contains(cf) | 479 | && (cf == 0 || app->categories().contains(cf) |
@@ -697,137 +689,137 @@ void LauncherView::setBusyIndicatorType( const QString& type ) { | |||
697 | void LauncherView::hideIcons() | 689 | void LauncherView::hideIcons() |
698 | { | 690 | { |
699 | icons->hide(); | 691 | icons->hide(); |
700 | } | 692 | } |
701 | 693 | ||
702 | void LauncherView::setToolsEnabled(bool y) | 694 | void LauncherView::setToolsEnabled(bool y) |
703 | { | 695 | { |
704 | if ( !y != !tools ) { | 696 | if ( !y != !tools ) { |
705 | if ( y ) { | 697 | if ( y ) { |
706 | tools = new QHBox(this); | 698 | tools = new QHBox(this); |
707 | 699 | // Type filter | |
708 | // Type filter | 700 | typemb = new QComboBox(tools); |
709 | typemb = new QComboBox(tools); | 701 | QSizePolicy p = typemb->sizePolicy(); |
710 | QSizePolicy p = typemb->sizePolicy(); | 702 | p.setHorData(QSizePolicy::Expanding); |
711 | p.setHorData(QSizePolicy::Expanding); | 703 | typemb->setSizePolicy(p); |
712 | typemb->setSizePolicy(p); | 704 | // Category filter |
713 | 705 | updateTools(); | |
714 | // Category filter | 706 | tools->show(); |
715 | updateTools(); | 707 | } else { |
716 | tools->show(); | 708 | delete tools; |
717 | 709 | tools = 0; | |
718 | } else { | 710 | } |
719 | delete tools; | ||
720 | tools = 0; | ||
721 | } | ||
722 | } | 711 | } |
723 | } | 712 | } |
724 | 713 | ||
725 | void LauncherView::updateTools() | 714 | void LauncherView::updateTools() |
726 | { | 715 | { |
727 | disconnect( typemb, SIGNAL(activated(int)), | 716 | disconnect( typemb, SIGNAL(activated(int)), |
728 | this, SLOT(showType(int)) ); | 717 | this, SLOT(showType(int)) ); |
729 | if ( catmb ) disconnect( catmb, SIGNAL(signalSelected(int)), | 718 | if ( catmb ) { |
730 | this, SLOT(showCategory(int)) ); | 719 | disconnect( catmb, SIGNAL(signalSelected(int)),this,SLOT(showCategory(int))); |
720 | } | ||
731 | 721 | ||
732 | // ### I want to remove this | 722 | // ### I want to remove this |
733 | icons->updateCategoriesAndMimeTypes(); | 723 | icons->updateCategoriesAndMimeTypes(); |
734 | 724 | ||
735 | QString prev; | 725 | QString prev; |
736 | 726 | ||
737 | // Type filter | 727 | // Type filter |
738 | QStringList types; | 728 | QStringList types; |
739 | typelist = icons->mimeTypes(); | 729 | typelist = icons->mimeTypes(); |
740 | for (QStringList::ConstIterator it = typelist.begin(); it!=typelist.end(); ++it) { | 730 | for (QStringList::ConstIterator it = typelist.begin(); it!=typelist.end(); ++it) { |
741 | QString t = *it; | 731 | QString t = *it; |
742 | if ( t.left(12) == "application/" ) { | 732 | if ( t.left(12) == "application/" ) { |
743 | MimeType mt(t); | 733 | MimeType mt(t); |
744 | const AppLnk* app = mt.application(); | 734 | const AppLnk* app = mt.application(); |
745 | if ( app ) | 735 | if ( app ) |
746 | t = app->name(); | 736 | t = app->name(); |
747 | else | 737 | else |
748 | t = t.mid(12); | 738 | t = t.mid(12); |
749 | } else { | 739 | } else { |
750 | t[0] = t[0].upper(); | 740 | t[0] = t[0].upper(); |
751 | } | 741 | } |
752 | types += t; | 742 | types += t; |
753 | } | 743 | } |
754 | types << tr("All types"); | 744 | types << tr("All types"); |
755 | prev = typemb->currentText(); | 745 | prev = typemb->currentText(); |
756 | typemb->clear(); | 746 | typemb->clear(); |
757 | typemb->insertStringList(types); | 747 | typemb->insertStringList(types); |
758 | for (int i=0; i<typemb->count(); i++) { | 748 | for (int i=0; i<typemb->count(); i++) { |
759 | if ( typemb->text(i) == prev ) { | 749 | if ( typemb->text(i) == prev ) { |
760 | typemb->setCurrentItem(i); | 750 | typemb->setCurrentItem(i); |
761 | break; | 751 | break; |
752 | } | ||
762 | } | 753 | } |
754 | if ( prev.isNull() ) { | ||
755 | typemb->setCurrentItem(typemb->count()-1); | ||
763 | } | 756 | } |
764 | if ( prev.isNull() ) | ||
765 | typemb->setCurrentItem(typemb->count()-1); | ||
766 | 757 | ||
767 | int pcat = catmb ? catmb->currentCategory() : -2; | 758 | int pcat = catmb ? catmb->currentCategory() : -2; |
768 | if ( !catmb ) | 759 | if ( !catmb ) |
769 | catmb = new CategorySelect(tools); | 760 | catmb = new CategorySelect(tools); |
770 | Categories cats( 0 ); | 761 | Categories cats( 0 ); |
771 | cats.load( categoryFileName() ); | 762 | cats.load( categoryFileName() ); |
772 | QArray<int> vl( 0 ); | 763 | QArray<int> vl( 0 ); |
773 | catmb->setCategories( vl, "Document View", // No tr | 764 | catmb->setCategories( vl, "Document View", // No tr |
774 | tr("Document View") ); | 765 | tr("Document View") ); |
775 | catmb->setRemoveCategoryEdit( TRUE ); | 766 | catmb->setRemoveCategoryEdit( TRUE ); |
776 | catmb->setAllCategories( TRUE ); | 767 | catmb->setAllCategories( TRUE ); |
777 | catmb->setCurrentCategory(pcat); | 768 | catmb->setCurrentCategory(pcat); |
778 | 769 | ||
779 | // if type has changed we need to redisplay | 770 | // if type has changed we need to redisplay |
780 | if ( typemb->currentText() != prev ) | 771 | if ( typemb->currentText() != prev ) |
781 | showType( typemb->currentItem() ); | 772 | showType( typemb->currentItem() ); |
782 | 773 | ||
783 | connect(typemb, SIGNAL(activated(int)), this, SLOT(showType(int))); | 774 | connect(typemb, SIGNAL(activated(int)), this, SLOT(showType(int))); |
784 | connect(catmb, SIGNAL(signalSelected(int)), this, SLOT(showCategory(int))); | 775 | connect(catmb, SIGNAL(signalSelected(int)), this, SLOT(showCategory(int))); |
785 | } | 776 | } |
786 | 777 | ||
787 | void LauncherView::sortBy(int s) | 778 | void LauncherView::sortBy(int s) |
788 | { | 779 | { |
789 | icons->setSortMethod((LauncherIconView::SortMethod)s); | 780 | icons->setSortMethod((LauncherIconView::SortMethod)s); |
790 | } | 781 | } |
791 | 782 | ||
792 | void LauncherView::showType(int t) | 783 | void LauncherView::showType(int t) |
793 | { | 784 | { |
794 | if ( t >= (int)typelist.count() ) { | 785 | if ( t >= (int)typelist.count() ) { |
795 | icons->setTypeFilter("",TRUE); | 786 | icons->setTypeFilter("",TRUE); |
796 | } else { | 787 | } else { |
797 | QString ty = typelist[t]; | 788 | QString ty = typelist[t]; |
798 | if ( !ty.contains('/') ) | 789 | if ( !ty.contains('/') ) |
799 | ty += "/*"; | 790 | ty += "/*"; |
800 | icons->setTypeFilter(ty,TRUE); | 791 | icons->setTypeFilter(ty,TRUE); |
801 | } | 792 | } |
802 | } | 793 | } |
803 | 794 | ||
804 | void LauncherView::showCategory( int c ) | 795 | void LauncherView::showCategory( int c ) |
805 | { | 796 | { |
806 | icons->setCategoryFilter( c, TRUE ); | 797 | icons->setCategoryFilter( c, TRUE ); |
807 | } | 798 | } |
808 | 799 | ||
809 | void LauncherView::setViewMode( ViewMode m ) | 800 | void LauncherView::setViewMode( ViewMode m ) |
810 | { | 801 | { |
802 | odebug << "LauncherView::setViewMode( ViewMode m )" << oendl; | ||
811 | if ( vmode != m ) { | 803 | if ( vmode != m ) { |
812 | bool bigIcons = m == Icon; | 804 | bool bigIcons = m == Icon; |
813 | icons->viewport()->setUpdatesEnabled( FALSE ); | 805 | icons->viewport()->setUpdatesEnabled( FALSE ); |
814 | icons->setBigIcons( bigIcons ); | 806 | icons->setBigIcons( bigIcons ); |
815 | switch ( m ) { | 807 | switch ( m ) { |
816 | case List: | 808 | case List: |
817 | icons->setItemTextPos( QIconView::Right ); | 809 | icons->setItemTextPos( QIconView::Right ); |
818 | break; | 810 | break; |
819 | case Icon: | 811 | case Icon: |
820 | icons->setItemTextPos( QIconView::Bottom ); | 812 | icons->setItemTextPos( QIconView::Bottom ); |
821 | break; | 813 | break; |
822 | } | 814 | } |
823 | icons->hideOrShowItems( FALSE ); | 815 | icons->hideOrShowItems( FALSE ); |
824 | icons->viewport()->setUpdatesEnabled( TRUE ); | 816 | icons->viewport()->setUpdatesEnabled( TRUE ); |
825 | vmode = m; | 817 | vmode = m; |
826 | } | 818 | } |
827 | } | 819 | } |
828 | 820 | ||
829 | // | 821 | // |
830 | // User images may require scaling. | 822 | // User images may require scaling. |
831 | // | 823 | // |
832 | QImage LauncherView::loadBackgroundImage(QString &bgName) | 824 | QImage LauncherView::loadBackgroundImage(QString &bgName) |
833 | { | 825 | { |
@@ -1041,16 +1033,17 @@ void LauncherView::itemPressed( int btn, QIconViewItem *item ) | |||
1041 | else if ( btn == ShiftButton ) | 1033 | else if ( btn == ShiftButton ) |
1042 | emit rightPressed( appLnk ); | 1034 | emit rightPressed( appLnk ); |
1043 | item->setSelected(FALSE); | 1035 | item->setSelected(FALSE); |
1044 | } | 1036 | } |
1045 | } | 1037 | } |
1046 | 1038 | ||
1047 | void LauncherView::removeAllItems() | 1039 | void LauncherView::removeAllItems() |
1048 | { | 1040 | { |
1041 | odebug << "LauncherView::removeAllItems()" << oendl; | ||
1049 | icons->clear(); | 1042 | icons->clear(); |
1050 | } | 1043 | } |
1051 | 1044 | ||
1052 | bool LauncherView::removeLink(const QString& linkfile) | 1045 | bool LauncherView::removeLink(const QString& linkfile) |
1053 | { | 1046 | { |
1054 | return icons->removeLink(linkfile); | 1047 | return icons->removeLink(linkfile); |
1055 | } | 1048 | } |
1056 | 1049 | ||
@@ -1163,17 +1156,17 @@ void LauncherThumbReceiver::recieve( const QCString&str, const QByteArray&at ) | |||
1163 | 1156 | ||
1164 | void LauncherThumbReceiver::requestThumb(const QString&file,int width,int height) | 1157 | void LauncherThumbReceiver::requestThumb(const QString&file,int width,int height) |
1165 | { | 1158 | { |
1166 | PixmapInfo rItem; | 1159 | PixmapInfo rItem; |
1167 | rItem.file = file; | 1160 | rItem.file = file; |
1168 | rItem.width = width; | 1161 | rItem.width = width; |
1169 | rItem.height = height; | 1162 | rItem.height = height; |
1170 | m_inThumbNail.append(rItem); | 1163 | m_inThumbNail.append(rItem); |
1171 | QTimer::singleShot(0, this, SLOT(sendRequest())); | 1164 | QTimer::singleShot(2, this, SLOT(sendRequest())); |
1172 | } | 1165 | } |
1173 | 1166 | ||
1174 | void LauncherThumbReceiver::sendRequest() | 1167 | void LauncherThumbReceiver::sendRequest() |
1175 | { | 1168 | { |
1176 | if (m_inThumbNail.count()>0) { | 1169 | if (m_inThumbNail.count()>0) { |
1177 | QCopEnvelope env("QPE/opie-eye_slave", "pixmapInfos(PixmapInfos)" ); | 1170 | QCopEnvelope env("QPE/opie-eye_slave", "pixmapInfos(PixmapInfos)" ); |
1178 | env << m_inThumbNail; | 1171 | env << m_inThumbNail; |
1179 | m_inThumbNail.clear(); | 1172 | m_inThumbNail.clear(); |
diff --git a/core/launcher/launcherview.h b/core/launcher/launcherview.h index 94c367c..6d94539 100644 --- a/core/launcher/launcherview.h +++ b/core/launcher/launcherview.h | |||
@@ -235,12 +235,11 @@ private: | |||
235 | QPixmap bgPixmap; | 235 | QPixmap bgPixmap; |
236 | QColor bgColor; | 236 | QColor bgColor; |
237 | LauncherThumbReceiver*m_EyeCallBack; | 237 | LauncherThumbReceiver*m_EyeCallBack; |
238 | #ifdef USE_ANIMATED_BUSY_ICON_OVERLAY | 238 | #ifdef USE_ANIMATED_BUSY_ICON_OVERLAY |
239 | QPixmap busyPix; | 239 | QPixmap busyPix; |
240 | #endif | 240 | #endif |
241 | BusyIndicatorType busyType; | 241 | BusyIndicatorType busyType; |
242 | QTimer m_eyeTimer; | 242 | QTimer m_eyeTimer; |
243 | QMap<QString,LauncherItem*> m_itemCache; | ||
244 | }; | 243 | }; |
245 | 244 | ||
246 | #endif // LAUNCHERVIEW_H | 245 | #endif // LAUNCHERVIEW_H |