summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2002-03-24 21:58:35 (UTC)
committer llornkcor <llornkcor>2002-03-24 21:58:35 (UTC)
commit59e2a88589d8d3fce1a395d073516d99b4e46e78 (patch) (unidiff)
tree6bcad0ead84cdacca7a264d0bf0347c675103403
parente37311c84c3f14f947a4e28df809898d23cb2495 (diff)
downloadopie-59e2a88589d8d3fce1a395d073516d99b4e46e78.zip
opie-59e2a88589d8d3fce1a395d073516d99b4e46e78.tar.gz
opie-59e2a88589d8d3fce1a395d073516d99b4e46e78.tar.bz2
changes sent in by Max Weninger
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/unsupported/filebrowser/filebrowser.cpp132
-rw-r--r--noncore/unsupported/filebrowser/filebrowser.h18
-rw-r--r--noncore/unsupported/filebrowser/opie-filebrowser.control2
-rw-r--r--pics/symlink.pngbin0 -> 103 bytes
4 files changed, 117 insertions, 35 deletions
diff --git a/noncore/unsupported/filebrowser/filebrowser.cpp b/noncore/unsupported/filebrowser/filebrowser.cpp
index 6f82f95..34d5177 100644
--- a/noncore/unsupported/filebrowser/filebrowser.cpp
+++ b/noncore/unsupported/filebrowser/filebrowser.cpp
@@ -27,2 +27,3 @@
27#include <qpe/applnk.h> 27#include <qpe/applnk.h>
28#include <qpe/config.h>
28 29
@@ -63,4 +64,6 @@ FileItem::FileItem( QListView * parent, const QFileInfo & fi )
63 64
64 if( fi.isDir() ) 65 if ( fi.isSymLink() )
65 setText( 3, "directory" ); 66 setText( 3, "symlink" );
67 else if( fi.isDir() )
68 setText( 3, "directory" );
66 else if( isLib() ) 69 else if( isLib() )
@@ -85,2 +88,9 @@ FileItem::FileItem( QListView * parent, const QFileInfo & fi )
85 pm = Resource::loadPixmap("UnknownDocument-14"); 88 pm = Resource::loadPixmap("UnknownDocument-14");
89 if( fi.isSymLink() ){
90 // overlay link image
91 QPixmap lnk = Resource::loadPixmap( "symlink" );
92 QPainter painter( &pm );
93 painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk );
94 pm.setMask( pm.createHeuristicMask( FALSE ) );
95 }
86 setPixmap(0,pm); 96 setPixmap(0,pm);
@@ -167,3 +177,4 @@ bool FileItem::rename( const QString & name )
167FileView::FileView( const QString & dir, QWidget * parent, 177FileView::FileView( const QString & dir, QWidget * parent,
168 const char * name ) 178 const char * name,
179 bool hidden, bool symlinks )
169 : QListView( parent, name ), 180 : QListView( parent, name ),
@@ -171,3 +182,6 @@ FileView::FileView( const QString & dir, QWidget * parent,
171 le( NULL ), 182 le( NULL ),
172 itemToRename( NULL ) 183 itemToRename( NULL ),
184 showHidden( hidden ),
185 showSymlinks( symlinks),
186 menuKeepsOpen( FALSE )
173{ 187{
@@ -178,6 +192,4 @@ FileView::FileView( const QString & dir, QWidget * parent,
178 192
179 showingHidden=FALSE;
180
181 setMultiSelection( TRUE ); 193 setMultiSelection( TRUE );
182 header()->hide(); 194 //header()->hide();
183 195
@@ -204,3 +216,3 @@ void FileView::resizeEvent( QResizeEvent *e )
204 // hide type column, we use it for "sort by type" only 216 // hide type column, we use it for "sort by type" only
205 setColumnWidth( 3, 0 ); 217 //setColumnWidth( 3, 0 );
206 QListView::resizeEvent( e ); 218 QListView::resizeEvent( e );
@@ -226,3 +238,6 @@ void FileView::generateDir( const QString & dir )
226{ 238{
227 QDir d( dir ); 239 if(menuKeepsOpen){
240 cancelMenuTimer();
241 }
242 QDir d( dir );
228 243
@@ -232,3 +247,3 @@ void FileView::generateDir( const QString & dir )
232 247
233 if( !showingHidden) 248 if( !showHidden)
234 d.setFilter( QDir::Dirs | QDir::Files ); 249 d.setFilter( QDir::Dirs | QDir::Files );
@@ -250,3 +265,7 @@ void FileView::generateDir( const QString & dir )
250 } 265 }
251 (void) new FileItem( (QListView *) this, *fi ); 266 if(!showSymlinks && fi->isSymLink()){
267 ++it;
268 continue;
269 }
270 (void) new FileItem( (QListView *) this, *fi );
252 ++it; 271 ++it;
@@ -572,3 +591,7 @@ void FileView::itemDblClicked( QListViewItem * i)
572{ 591{
573 FileItem * t = (FileItem *) i; 592 if(menuKeepsOpen){
593 cancelMenuTimer();
594 }
595
596 FileItem * t = (FileItem *) i;
574 597
@@ -604,3 +627,6 @@ void FileView::contentsMouseReleaseEvent( QMouseEvent * e )
604 QListView::contentsMouseReleaseEvent( e ); 627 QListView::contentsMouseReleaseEvent( e );
605 menuTimer.stop(); 628 if(!menuKeepsOpen){
629 menuTimer.stop();
630 }
631
606} 632}
@@ -678,2 +704,17 @@ void FileView::showFileMenu()
678 704
705void FileView::setShowHidden(bool hidden)
706{
707 showHidden=hidden;
708}
709
710void FileView::setShowSymlinks(bool symlinks)
711{
712 showSymlinks=symlinks;
713}
714
715void FileView::setMenuKeepsOpen(bool keepOpen)
716{
717 menuKeepsOpen=keepOpen;
718}
719
679FileBrowser::FileBrowser( QWidget * parent, 720FileBrowser::FileBrowser( QWidget * parent,
@@ -697,5 +738,15 @@ void FileBrowser::init(const QString & dir)
697 738
698 fileView = new FileView( dir, this ); 739 Config cfg("Filebrowser");
699 fileView->setAllColumnsShowFocus( TRUE ); 740 cfg.setGroup("View");
741 bool showHidden=(cfg.readEntry("Hidden","FALSE") == "TRUE");
742 bool showSymlinks=(cfg.readEntry("Symlinks","FALSE") == "TRUE");
743
744 cfg.setGroup("Menu");
745 bool menuKeepsOpen=(cfg.readEntry("KeepOpen", "FALSE") == "TRUE");
746
700 747
748 fileView = new FileView( dir, this, 0, showHidden, showSymlinks );
749 fileView->setAllColumnsShowFocus( TRUE );
750 fileView->setMenuKeepsOpen(menuKeepsOpen);
751
701 setCentralWidget( fileView ); 752 setCentralWidget( fileView );
@@ -719,6 +770,2 @@ void FileBrowser::init(const QString & dir)
719 sortMenu->insertItem( tr( "Ascending" ), this, SLOT( updateSorting() ) ); 770 sortMenu->insertItem( tr( "Ascending" ), this, SLOT( updateSorting() ) );
720 sortMenu->insertSeparator();
721 sortMenu->insertItem( tr( "Show Hidden "), this, SLOT( showHidden() ) );
722
723// fileView->showingHidden=FALSE;
724 771
@@ -727,2 +774,10 @@ void FileBrowser::init(const QString & dir)
727 774
775 viewMenu = new QPopupMenu( this);
776 viewMenu->insertItem( tr( "Hidden"), this, SLOT( updateShowHidden() ) );
777 viewMenu->insertItem( tr( "Symlinks"), this, SLOT( updateShowSymlinks() ) );
778 viewMenu->setItemChecked( viewMenu->idAt( 0 ), showHidden );
779 viewMenu->setItemChecked( viewMenu->idAt( 1 ), showSymlinks );
780
781 menuBar->insertItem( tr("View"), viewMenu );
782
728 toolBar = new QPEToolBar( this ); 783 toolBar = new QPEToolBar( this );
@@ -872,13 +927,2 @@ void FileBrowser::updateSorting()
872 927
873void FileBrowser::showHidden() {
874 if(!fileView->showingHidden) {
875 fileView->showingHidden=TRUE;
876 sortMenu->setItemChecked( sortMenu->idAt( 7),TRUE);
877 } else {
878 fileView->showingHidden=FALSE;
879 sortMenu->setItemChecked( sortMenu->idAt( 7),FALSE);
880 }
881 fileView->updateDir();
882}
883
884void FileView::chPerm() { 928void FileView::chPerm() {
@@ -911 +955,29 @@ void FileView::chPerm() {
911} 955}
956
957void FileBrowser::updateShowHidden()
958{
959 bool valShowHidden=viewMenu->isItemChecked( viewMenu->idAt( 0 ) );
960 valShowHidden=!valShowHidden;
961 viewMenu->setItemChecked( viewMenu->idAt( 0 ), valShowHidden );
962 fileView->setShowHidden(valShowHidden);
963
964 Config cfg("Filebrowser");
965 cfg.setGroup("View");
966 cfg.writeEntry("Hidden",valShowHidden?"TRUE":"FALSE");
967
968 fileView->updateDir();
969}
970
971void FileBrowser::updateShowSymlinks()
972{
973 bool valShowSymlinks=viewMenu->isItemChecked( viewMenu->idAt( 1 ) );
974 valShowSymlinks=!valShowSymlinks;
975 viewMenu->setItemChecked( viewMenu->idAt( 1 ), valShowSymlinks );
976 fileView->setShowSymlinks(valShowSymlinks);
977
978 Config cfg("Filebrowser");
979 cfg.setGroup("View");
980 cfg.writeEntry("Symlinks",valShowSymlinks?"TRUE":"FALSE");
981
982 fileView->updateDir();
983}
diff --git a/noncore/unsupported/filebrowser/filebrowser.h b/noncore/unsupported/filebrowser/filebrowser.h
index 54856a0..983e58e 100644
--- a/noncore/unsupported/filebrowser/filebrowser.h
+++ b/noncore/unsupported/filebrowser/filebrowser.h
@@ -56,3 +56,6 @@ public:
56 FileView( const QString & dir, QWidget * parent = 0, 56 FileView( const QString & dir, QWidget * parent = 0,
57 const char * name = 0 ); 57 const char * name = 0,
58 bool hidden = FALSE,
59 bool symlinks = FALSE );
60
58 void setDir( const QString & dir ); 61 void setDir( const QString & dir );
@@ -62,2 +65,6 @@ public:
62 65
66 void setShowHidden(bool hidden);
67 void setShowSymlinks(bool symlinks);
68 void setMenuKeepsOpen(bool keepOpen);
69
63public slots: 70public slots:
@@ -99,2 +106,5 @@ private:
99 bool selected; 106 bool selected;
107 bool showHidden;
108 bool showSymlinks;
109 bool menuKeepsOpen;
100 110
@@ -122,3 +132,3 @@ private:
122 QString fileToCopy; 132 QString fileToCopy;
123 QPopupMenu * dirMenu, * sortMenu; 133 QPopupMenu * dirMenu, * sortMenu, *viewMenu;
124 FileView * fileView; 134 FileView * fileView;
@@ -138,6 +148,6 @@ private slots:
138 void updateSorting(); 148 void updateSorting();
139 149 void updateShowHidden();
150 void updateShowSymlinks();
140 void updateDirMenu(); 151 void updateDirMenu();
141 void dirSelected( int id ); 152 void dirSelected( int id );
142 void showHidden();
143}; 153};
diff --git a/noncore/unsupported/filebrowser/opie-filebrowser.control b/noncore/unsupported/filebrowser/opie-filebrowser.control
index c15ae17..0b8528a 100644
--- a/noncore/unsupported/filebrowser/opie-filebrowser.control
+++ b/noncore/unsupported/filebrowser/opie-filebrowser.control
@@ -1,2 +1,2 @@
1Files: bin/filebrowser apps/Applications/filebrowser.desktop 1Files: bin/filebrowser apps/Applications/filebrowser.desktop pics/symlink.png
2Priority: optional 2Priority: optional
diff --git a/pics/symlink.png b/pics/symlink.png
new file mode 100644
index 0000000..a0b267a
--- a/dev/null
+++ b/pics/symlink.png
Binary files differ