author | llornkcor <llornkcor> | 2002-03-25 02:46:56 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-03-25 02:46:56 (UTC) |
commit | b43c59f2f8da6edfa37042e0838b38702636f4d1 (patch) (unidiff) | |
tree | 31913b2d26759d404c570c2164949da5b0796027 | |
parent | d8820a9f2bdf9bc98c99542e3613ca9b5d2c6e0c (diff) | |
download | opie-b43c59f2f8da6edfa37042e0838b38702636f4d1.zip opie-b43c59f2f8da6edfa37042e0838b38702636f4d1.tar.gz opie-b43c59f2f8da6edfa37042e0838b38702636f4d1.tar.bz2 |
added more icon stuff
-rw-r--r-- | core/apps/textedit/fileBrowser.cpp | 53 |
1 files changed, 30 insertions, 23 deletions
diff --git a/core/apps/textedit/fileBrowser.cpp b/core/apps/textedit/fileBrowser.cpp index acd50c2..ebb78d1 100644 --- a/core/apps/textedit/fileBrowser.cpp +++ b/core/apps/textedit/fileBrowser.cpp | |||
@@ -1,476 +1,483 @@ | |||
1 | /**************************************************************************** | 1 | /**************************************************************************** |
2 | ** copyright 2001 ljp ljp@llornkcor.com | 2 | ** copyright 2001 ljp ljp@llornkcor.com |
3 | ** Created: Fri Dec 14 08:16:46 2001 | 3 | ** Created: Fri Dec 14 08:16:46 2001 |
4 | ** | 4 | ** |
5 | ** This file may be distributed and/or modified under the terms of the | 5 | ** This file may be distributed and/or modified under the terms of the |
6 | ** GNU General Public License version 2 as published by the Free Software | 6 | ** GNU General Public License version 2 as published by the Free Software |
7 | ** Foundation and appearing in the file LICENSE.GPL included in the | 7 | ** Foundation and appearing in the file LICENSE.GPL included in the |
8 | ** packaging of this file. | 8 | ** packaging of this file. |
9 | ** | 9 | ** |
10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 10 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
11 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 11 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
12 | ** | 12 | ** |
13 | ****************************************************************************/ | 13 | ****************************************************************************/ |
14 | #include "fileBrowser.h" | 14 | #include "fileBrowser.h" |
15 | #include "inputDialog.h" | 15 | #include "inputDialog.h" |
16 | 16 | ||
17 | #include <qpe/config.h> | 17 | #include <qpe/config.h> |
18 | #include <qpe/resource.h> | 18 | #include <qpe/resource.h> |
19 | #include <qpe/fileselector.h> | 19 | #include <qpe/fileselector.h> |
20 | #include <qpe/qpeapplication.h> | 20 | #include <qpe/qpeapplication.h> |
21 | #include <qpe/menubutton.h> | 21 | #include <qpe/menubutton.h> |
22 | #include <qpe/mimetype.h> | ||
22 | 23 | ||
23 | #include <qdict.h> | 24 | #include <qdict.h> |
24 | #include <qwidgetstack.h> | 25 | #include <qwidgetstack.h> |
25 | #include <qlistview.h> | 26 | #include <qlistview.h> |
26 | #include <qcombo.h> | 27 | #include <qcombo.h> |
27 | #include <qpushbutton.h> | 28 | #include <qpushbutton.h> |
28 | #include <qfile.h> | 29 | #include <qfile.h> |
29 | #include <qmessagebox.h> | 30 | #include <qmessagebox.h> |
30 | #include <qlayout.h> | 31 | #include <qlayout.h> |
31 | #include <unistd.h> | 32 | #include <unistd.h> |
32 | #include <qpopupmenu.h> | 33 | #include <qpopupmenu.h> |
33 | #include <qlineedit.h> | 34 | #include <qlineedit.h> |
34 | #include <qstringlist.h> | 35 | #include <qstringlist.h> |
35 | 36 | ||
36 | #include <unistd.h> | 37 | #include <unistd.h> |
37 | #include <stdlib.h> | 38 | #include <stdlib.h> |
38 | 39 | ||
39 | static int u_id = 1; | 40 | static int u_id = 1; |
40 | static int get_unique_id() | 41 | static int get_unique_id() |
41 | { | 42 | { |
42 | return u_id++; | 43 | return u_id++; |
43 | } | 44 | } |
44 | 45 | ||
45 | fileBrowser::fileBrowser( QWidget* parent, const char* name, bool modal, WFlags fl , const QString filter ) | 46 | fileBrowser::fileBrowser( QWidget* parent, const char* name, bool modal, WFlags fl , const QString filter ) |
46 | : QDialog( parent, name, modal, fl ) | 47 | : QDialog( parent, name, modal, fl ) |
47 | { | 48 | { |
48 | if ( !name ) | 49 | if ( !name ) |
49 | setName( "fileBrowser" ); | 50 | setName( "fileBrowser" ); |
50 | setCaption(tr( name ) ); | 51 | setCaption(tr( name ) ); |
51 | filterStr=filter; | 52 | filterStr=filter; |
52 | 53 | ||
53 | // channel = new QCopChannel( "QPE/fileDialog", this ); | 54 | // channel = new QCopChannel( "QPE/fileDialog", this ); |
54 | // connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), | 55 | // connect( channel, SIGNAL(received(const QCString&, const QByteArray&)), |
55 | // this, SLOT(receive(const QCString&, const QByteArray&)) ); | 56 | // this, SLOT(receive(const QCString&, const QByteArray&)) ); |
56 | 57 | ||
57 | QGridLayout *layout = new QGridLayout( this ); | 58 | QGridLayout *layout = new QGridLayout( this ); |
58 | layout->setSpacing( 4 ); | 59 | layout->setSpacing( 4 ); |
59 | layout->setMargin( 4 ); | 60 | layout->setMargin( 4 ); |
60 | 61 | ||
61 | dirPathCombo = new QComboBox( FALSE, this, "dorPathCombo" ); | 62 | dirPathCombo = new QComboBox( FALSE, this, "dorPathCombo" ); |
62 | dirPathCombo->setEditable(TRUE); | 63 | dirPathCombo->setEditable(TRUE); |
63 | 64 | ||
64 | connect( dirPathCombo, SIGNAL( activated( const QString & ) ), | 65 | connect( dirPathCombo, SIGNAL( activated( const QString & ) ), |
65 | this, SLOT( dirPathComboActivated( const QString & ) ) ); | 66 | this, SLOT( dirPathComboActivated( const QString & ) ) ); |
66 | 67 | ||
67 | connect( dirPathCombo->lineEdit(), SIGNAL( returnPressed( ) ), | 68 | connect( dirPathCombo->lineEdit(), SIGNAL( returnPressed( ) ), |
68 | this, SLOT( dirPathEditPressed( ) ) ); | 69 | this, SLOT( dirPathEditPressed( ) ) ); |
69 | 70 | ||
70 | dirPathStringList << "/"; | 71 | dirPathStringList << "/"; |
71 | // we can get the storage here | 72 | // we can get the storage here |
72 | 73 | ||
73 | layout->addMultiCellWidget( dirPathCombo, 0, 0, 0, 4 ); | 74 | layout->addMultiCellWidget( dirPathCombo, 0, 0, 0, 4 ); |
74 | 75 | ||
75 | cdUpButton = new QPushButton(Resource::loadIconSet("up"),"",this,"cdUpButton"); | 76 | cdUpButton = new QPushButton(Resource::loadIconSet("up"),"",this,"cdUpButton"); |
76 | cdUpButton ->setMinimumSize( QSize( 20, 20 ) ); | 77 | cdUpButton ->setMinimumSize( QSize( 20, 20 ) ); |
77 | cdUpButton ->setMaximumSize( QSize( 20, 20 ) ); | 78 | cdUpButton ->setMaximumSize( QSize( 20, 20 ) ); |
78 | connect( cdUpButton ,SIGNAL(released()),this,SLOT( upDir()) ); | 79 | connect( cdUpButton ,SIGNAL(released()),this,SLOT( upDir()) ); |
79 | cdUpButton ->setFlat(TRUE); | 80 | cdUpButton ->setFlat(TRUE); |
80 | layout->addMultiCellWidget( cdUpButton, 0, 0, 5, 5 ); | 81 | layout->addMultiCellWidget( cdUpButton, 0, 0, 5, 5 ); |
81 | 82 | ||
82 | 83 | ||
83 | docButton = new QPushButton(Resource::loadIconSet("DocsIcon"),"",this,"docsButton"); | 84 | docButton = new QPushButton(Resource::loadIconSet("DocsIcon"),"",this,"docsButton"); |
84 | docButton->setMinimumSize( QSize( 20, 20 ) ); | 85 | docButton->setMinimumSize( QSize( 20, 20 ) ); |
85 | docButton->setMaximumSize( QSize( 20, 20 ) ); | 86 | docButton->setMaximumSize( QSize( 20, 20 ) ); |
86 | connect( docButton,SIGNAL(released()),this,SLOT( docButtonPushed()) ); | 87 | connect( docButton,SIGNAL(released()),this,SLOT( docButtonPushed()) ); |
87 | docButton->setFlat(TRUE); | 88 | docButton->setFlat(TRUE); |
88 | layout->addMultiCellWidget( docButton, 0, 0, 6, 6 ); | 89 | layout->addMultiCellWidget( docButton, 0, 0, 6, 6 ); |
89 | 90 | ||
90 | homeButton = new QPushButton( Resource::loadIconSet("home"),"",this,"homeButton"); | 91 | homeButton = new QPushButton( Resource::loadIconSet("home"),"",this,"homeButton"); |
91 | homeButton->setMinimumSize( QSize( 20, 20 ) ); | 92 | homeButton->setMinimumSize( QSize( 20, 20 ) ); |
92 | homeButton->setMaximumSize( QSize( 20, 20 ) ); | 93 | homeButton->setMaximumSize( QSize( 20, 20 ) ); |
93 | connect(homeButton,SIGNAL(released()),this,SLOT(homeButtonPushed()) ); | 94 | connect(homeButton,SIGNAL(released()),this,SLOT(homeButtonPushed()) ); |
94 | homeButton->setFlat(TRUE); | 95 | homeButton->setFlat(TRUE); |
95 | layout->addMultiCellWidget( homeButton, 0, 0, 7, 7 ); | 96 | layout->addMultiCellWidget( homeButton, 0, 0, 7, 7 ); |
96 | 97 | ||
97 | FileStack = new QWidgetStack( this ); | 98 | FileStack = new QWidgetStack( this ); |
98 | 99 | ||
99 | 100 | ||
100 | ListView = new QListView( this, "ListView" ); | 101 | ListView = new QListView( this, "ListView" ); |
101 | // ListView->setMinimumSize( QSize( 100, 25 ) ); | 102 | // ListView->setMinimumSize( QSize( 100, 25 ) ); |
102 | ListView->addColumn( tr( "Name" ) ); | 103 | ListView->addColumn( tr( "Name" ) ); |
103 | ListView->setColumnWidth(0,120); | 104 | ListView->setColumnWidth(0,120); |
104 | ListView->setSorting( 2, FALSE); | 105 | ListView->setSorting( 2, FALSE); |
105 | ListView->addColumn( tr( "Size" ) ); | 106 | ListView->addColumn( tr( "Size" ) ); |
106 | ListView->setColumnWidth(1,-1); | 107 | ListView->setColumnWidth(1,-1); |
107 | ListView->addColumn( "Date",-1); | 108 | ListView->addColumn( "Date",-1); |
108 | 109 | ||
109 | ListView->setColumnWidthMode(0,QListView::Manual); | 110 | ListView->setColumnWidthMode(0,QListView::Manual); |
110 | ListView->setColumnAlignment(1,QListView::AlignRight); | 111 | ListView->setColumnAlignment(1,QListView::AlignRight); |
111 | ListView->setColumnAlignment(2,QListView::AlignRight); | 112 | ListView->setColumnAlignment(2,QListView::AlignRight); |
112 | ListView->setAllColumnsShowFocus( TRUE ); | 113 | ListView->setAllColumnsShowFocus( TRUE ); |
113 | 114 | ||
114 | QPEApplication::setStylusOperation( ListView->viewport(),QPEApplication::RightOnHold); | 115 | QPEApplication::setStylusOperation( ListView->viewport(),QPEApplication::RightOnHold); |
115 | connect( ListView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), | 116 | connect( ListView, SIGNAL( mouseButtonPressed( int, QListViewItem *, const QPoint&, int)), |
116 | this,SLOT( ListPressed(int, QListViewItem *, const QPoint&, int)) ); | 117 | this,SLOT( ListPressed(int, QListViewItem *, const QPoint&, int)) ); |
117 | 118 | ||
118 | connect( ListView, SIGNAL( clicked( QListViewItem*)), SLOT(listClicked(QListViewItem *)) ); | 119 | connect( ListView, SIGNAL( clicked( QListViewItem*)), SLOT(listClicked(QListViewItem *)) ); |
119 | 120 | ||
120 | FileStack->addWidget( ListView, get_unique_id() ); | 121 | FileStack->addWidget( ListView, get_unique_id() ); |
121 | mimeType="text/*"; | 122 | mimeType="text/*"; |
122 | fileSelector = new FileSelector( mimeType, FileStack, "fileselector" , FALSE, FALSE); //buggy | 123 | fileSelector = new FileSelector( mimeType, FileStack, "fileselector" , FALSE, FALSE); //buggy |
123 | // connect( fileSelector, SIGNAL( closeMe() ), this, SLOT( showEditTools() ) ); | 124 | // connect( fileSelector, SIGNAL( closeMe() ), this, SLOT( showEditTools() ) ); |
124 | // connect( fileSelector, SIGNAL( newSelected( const DocLnk &) ), this, SLOT( newFile( const DocLnk & ) ) ); | 125 | // connect( fileSelector, SIGNAL( newSelected( const DocLnk &) ), this, SLOT( newFile( const DocLnk & ) ) ); |
125 | connect( fileSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( docOpen( const DocLnk & ) ) ); | 126 | connect( fileSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( docOpen( const DocLnk & ) ) ); |
126 | layout->addMultiCellWidget( FileStack, 1, 1, 0, 7 ); | 127 | layout->addMultiCellWidget( FileStack, 1, 1, 0, 7 ); |
127 | 128 | ||
128 | SelectionCombo = new QComboBox( FALSE, this, "SelectionCombo" ); | 129 | SelectionCombo = new QComboBox( FALSE, this, "SelectionCombo" ); |
129 | SelectionCombo->insertItem( tr( "Documents" ) ); | 130 | SelectionCombo->insertItem( tr( "Documents" ) ); |
130 | SelectionCombo->insertItem( tr( "All files" ) ); | 131 | SelectionCombo->insertItem( tr( "All files" ) ); |
131 | SelectionCombo->insertItem( tr( "Hidden files" ) ); | 132 | SelectionCombo->insertItem( tr( "Hidden files" ) ); |
132 | // SelectionCombo->setMaximumWidth(120); | 133 | // SelectionCombo->setMaximumWidth(120); |
133 | layout->addMultiCellWidget( SelectionCombo, 2, 2, 0, 3 ); | 134 | layout->addMultiCellWidget( SelectionCombo, 2, 2, 0, 3 ); |
134 | 135 | ||
135 | connect( SelectionCombo, SIGNAL( activated( const QString & ) ), | 136 | connect( SelectionCombo, SIGNAL( activated( const QString & ) ), |
136 | this, SLOT( selectionChanged( const QString & ) ) ); | 137 | this, SLOT( selectionChanged( const QString & ) ) ); |
137 | 138 | ||
138 | typemb = new MenuButton(this); | 139 | typemb = new MenuButton(this); |
139 | typemb->setLabel(tr("Type: %1")); | 140 | typemb->setLabel(tr("Type: %1")); |
140 | typemb->setMinimumWidth(110); | 141 | typemb->setMinimumWidth(110); |
141 | typemb->setFixedHeight(22); | 142 | typemb->setFixedHeight(22); |
142 | layout->addMultiCellWidget( typemb, 2, 2, 4, 7 ); | 143 | layout->addMultiCellWidget( typemb, 2, 2, 4, 7 ); |
143 | updateMimeTypeMenu() ; | 144 | updateMimeTypeMenu() ; |
144 | 145 | ||
145 | currentDir.setPath(QDir::currentDirPath()); | 146 | currentDir.setPath(QDir::currentDirPath()); |
146 | currentDir.setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden */| QDir::All); | 147 | currentDir.setFilter( QDir::Files | QDir::Dirs/* | QDir::Hidden */| QDir::All); |
147 | 148 | ||
148 | populateList(); | 149 | populateList(); |
149 | move(0,15); | 150 | move(0,15); |
150 | } | 151 | } |
151 | 152 | ||
152 | fileBrowser::~fileBrowser() | 153 | fileBrowser::~fileBrowser() |
153 | { | 154 | { |
154 | } | 155 | } |
155 | 156 | ||
156 | void fileBrowser::setFileView( int selection ) | 157 | void fileBrowser::setFileView( int selection ) |
157 | { | 158 | { |
158 | SelectionCombo->setCurrentItem( selection ); | 159 | SelectionCombo->setCurrentItem( selection ); |
159 | selectionChanged( SelectionCombo->currentText() ); | 160 | selectionChanged( SelectionCombo->currentText() ); |
160 | } | 161 | } |
161 | 162 | ||
162 | void fileBrowser::populateList() | 163 | void fileBrowser::populateList() |
163 | { | 164 | { |
164 | ListView->clear(); | 165 | ListView->clear(); |
165 | bool isDir=FALSE; | 166 | bool isDir=FALSE; |
166 | //qDebug(currentDir.canonicalPath()); | 167 | //qDebug(currentDir.canonicalPath()); |
167 | currentDir.setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); | 168 | currentDir.setSorting(/* QDir::Size*/ /*| QDir::Reversed | */QDir::DirsFirst); |
168 | currentDir.setMatchAllDirs(TRUE); | 169 | currentDir.setMatchAllDirs(TRUE); |
169 | 170 | ||
170 | currentDir.setNameFilter(filterStr); | 171 | currentDir.setNameFilter(filterStr); |
171 | // currentDir.setNameFilter("*.txt;*.etx"); | 172 | // currentDir.setNameFilter("*.txt;*.etx"); |
172 | QString fileL, fileS, fileDate; | 173 | QString fileL, fileS, fileDate; |
173 | const QFileInfoList *list = currentDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); | 174 | const QFileInfoList *list = currentDir.entryInfoList( /*QDir::All*/ /*, QDir::SortByMask*/); |
174 | QFileInfoListIterator it(*list); | 175 | QFileInfoListIterator it(*list); |
175 | QFileInfo *fi; | 176 | QFileInfo *fi; |
176 | while ( (fi=it.current()) ) { | 177 | while ( (fi=it.current()) ) { |
177 | 178 | ||
178 | if (fi->isSymLink() ){ | 179 | if (fi->isSymLink() ){ |
179 | QString symLink=fi->readLink(); | 180 | QString symLink=fi->readLink(); |
180 | // qDebug("Symlink detected "+symLink); | 181 | // qDebug("Symlink detected "+symLink); |
181 | QFileInfo sym( symLink); | 182 | QFileInfo sym( symLink); |
182 | fileS.sprintf( "%10li", sym.size() ); | 183 | fileS.sprintf( "%10li", sym.size() ); |
183 | fileL.sprintf( "%s -> %s", sym.fileName().data(),sym.absFilePath().data() ); | 184 | fileL.sprintf( "%s -> %s", sym.fileName().data(),sym.absFilePath().data() ); |
184 | fileDate = sym.lastModified().toString(); | 185 | fileDate = sym.lastModified().toString(); |
185 | } else { | 186 | } else { |
186 | // qDebug("Not a dir: "+currentDir.canonicalPath()+fileL); | 187 | // qDebug("Not a dir: "+currentDir.canonicalPath()+fileL); |
187 | fileS.sprintf( "%10li", fi->size() ); | 188 | fileS.sprintf( "%10li", fi->size() ); |
188 | fileL.sprintf( "%s",fi->fileName().data() ); | 189 | fileL.sprintf( "%s",fi->fileName().data() ); |
189 | fileDate= fi->lastModified().toString(); | 190 | fileDate= fi->lastModified().toString(); |
190 | if( QDir(QDir::cleanDirPath(currentDir.canonicalPath()+"/"+fileL)).exists() ) { | 191 | if( QDir(QDir::cleanDirPath(currentDir.canonicalPath()+"/"+fileL)).exists() ) { |
191 | fileL+="/"; | 192 | fileL+="/"; |
192 | isDir=TRUE; | 193 | isDir=TRUE; |
193 | // qDebug( fileL); | 194 | // qDebug( fileL); |
194 | } | 195 | } |
195 | } | 196 | } |
196 | if(fileL !="./") { | 197 | if(fileL !="./") { |
197 | item= new QListViewItem( ListView,fileL,fileS , fileDate); | 198 | item= new QListViewItem( ListView,fileL,fileS , fileDate); |
198 | QPixmap pm; | 199 | QPixmap pm; |
199 | pm= Resource::loadPixmap( "folder" ); | ||
200 | 200 | ||
201 | if(isDir || fileL.find("/",0,TRUE) != -1) { | 201 | if(isDir || fileL.find("/",0,TRUE) != -1) { |
202 | if( !QDir( fi->filePath() ).isReadable()) | 202 | if( !QDir( fi->filePath() ).isReadable()) |
203 | pm = Resource::loadPixmap( "lockedfolder" ); | 203 | pm = Resource::loadPixmap( "lockedfolder" ); |
204 | item->setPixmap( 0,pm ); | 204 | else |
205 | } else { | 205 | pm= Resource::loadPixmap( "folder" ); |
206 | if( !fi->isReadable() ) | 206 | item->setPixmap( 0,pm ); |
207 | pm = Resource::loadPixmap( "locked" ); | 207 | } else { |
208 | else | 208 | if( !fi->isReadable() ) |
209 | pm = Resource::loadPixmap( "fileopen" ); | 209 | pm = Resource::loadPixmap( "locked" ); |
210 | item->setPixmap( 0,pm); | 210 | else { |
211 | } | 211 | MimeType mt(fi->filePath()); |
212 | if( fileL.find("->",0,TRUE) != -1) { | 212 | pm=mt.pixmap(); |
213 | // overlay link image | 213 | if(pm.isNull()) |
214 | QPixmap lnk = Resource::loadPixmap( "symlink" ); | 214 | pm = Resource::loadPixmap( "UnknownDocument-14" ); |
215 | QPainter painter( &pm ); | 215 | item->setPixmap( 0,pm); |
216 | painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); | 216 | } |
217 | pm.setMask( pm.createHeuristicMask( FALSE ) ); | 217 | } |
218 | item->setPixmap( 0, pm); | 218 | if( fileL.find("->",0,TRUE) != -1) { |
219 | // overlay link image | ||
220 | pm= Resource::loadPixmap( "folder" ); | ||
221 | QPixmap lnk = Resource::loadPixmap( "symlink" ); | ||
222 | QPainter painter( &pm ); | ||
223 | painter.drawPixmap( pm.width()-lnk.width(), pm.height()-lnk.height(), lnk ); | ||
224 | pm.setMask( pm.createHeuristicMask( FALSE ) ); | ||
225 | item->setPixmap( 0, pm); | ||
226 | } | ||
219 | } | 227 | } |
220 | } | ||
221 | isDir=FALSE; | 228 | isDir=FALSE; |
222 | ++it; | 229 | ++it; |
223 | } | 230 | } |
224 | ListView->setSorting( 3, FALSE); | 231 | ListView->setSorting( 3, FALSE); |
225 | QString currentPath = currentDir.canonicalPath(); | 232 | QString currentPath = currentDir.canonicalPath(); |
226 | 233 | ||
227 | fillCombo( (const QString &)currentPath); | 234 | fillCombo( (const QString &)currentPath); |
228 | // dirPathCombo->lineEdit()->setText(currentPath); | 235 | // dirPathCombo->lineEdit()->setText(currentPath); |
229 | 236 | ||
230 | // if( dirPathStringList.grep(currentPath,TRUE).isEmpty() ) { | 237 | // if( dirPathStringList.grep(currentPath,TRUE).isEmpty() ) { |
231 | // dirPathCombo->clear(); | 238 | // dirPathCombo->clear(); |
232 | // dirPathStringList.prepend(currentPath ); | 239 | // dirPathStringList.prepend(currentPath ); |
233 | // dirPathCombo->insertStringList( dirPathStringList,-1); | 240 | // dirPathCombo->insertStringList( dirPathStringList,-1); |
234 | // } | 241 | // } |
235 | } | 242 | } |
236 | 243 | ||
237 | void fileBrowser::upDir() | 244 | void fileBrowser::upDir() |
238 | { | 245 | { |
239 | QString current = currentDir.canonicalPath(); | 246 | QString current = currentDir.canonicalPath(); |
240 | QDir dir(current); | 247 | QDir dir(current); |
241 | dir.cdUp(); | 248 | dir.cdUp(); |
242 | current = dir.canonicalPath(); | 249 | current = dir.canonicalPath(); |
243 | chdir( current.latin1() ); | 250 | chdir( current.latin1() ); |
244 | currentDir.cd( current, TRUE); | 251 | currentDir.cd( current, TRUE); |
245 | populateList(); | 252 | populateList(); |
246 | update(); | 253 | update(); |
247 | } | 254 | } |
248 | 255 | ||
249 | // you may want to switch these 2 functions. I like single clicks | 256 | // you may want to switch these 2 functions. I like single clicks |
250 | void fileBrowser::listClicked(QListViewItem *selectedItem) | 257 | void fileBrowser::listClicked(QListViewItem *selectedItem) |
251 | { | 258 | { |
252 | QString strItem=selectedItem->text(0); | 259 | QString strItem=selectedItem->text(0); |
253 | QString strSize=selectedItem->text(1); | 260 | QString strSize=selectedItem->text(1); |
254 | // qDebug("strItem is "+strItem); | 261 | // qDebug("strItem is "+strItem); |
255 | strSize.stripWhiteSpace(); | 262 | strSize.stripWhiteSpace(); |
256 | // qDebug(strSize); | 263 | // qDebug(strSize); |
257 | 264 | ||
258 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 ) { //if symlink | 265 | if(strItem.find("@",0,TRUE) !=-1 || strItem.find("->",0,TRUE) !=-1 ) { //if symlink |
259 | // is symlink | 266 | // is symlink |
260 | QString strItem2=strItem.right( (strItem.length()-strItem.find("->",0,TRUE)) -4); | 267 | QString strItem2=strItem.right( (strItem.length()-strItem.find("->",0,TRUE)) -4); |
261 | // qDebug("strItem symlink is "+strItem2); | 268 | // qDebug("strItem symlink is "+strItem2); |
262 | if(QDir(strItem2).exists() ) { | 269 | if(QDir(strItem2).exists() ) { |
263 | currentDir.cd(strItem2, TRUE); | 270 | currentDir.cd(strItem2, TRUE); |
264 | populateList(); | 271 | populateList(); |
265 | } | 272 | } |
266 | } else { // not a symlink | 273 | } else { // not a symlink |
267 | if(strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) { | 274 | if(strItem.find(". .",0,TRUE) && strItem.find("/",0,TRUE)!=-1 ) { |
268 | if(QDir(QDir::cleanDirPath(currentDir.canonicalPath()+"/"+strItem)).exists() ) { | 275 | if(QDir(QDir::cleanDirPath(currentDir.canonicalPath()+"/"+strItem)).exists() ) { |
269 | strItem=QDir::cleanDirPath(currentDir.canonicalPath()+"/"+strItem); | 276 | strItem=QDir::cleanDirPath(currentDir.canonicalPath()+"/"+strItem); |
270 | currentDir.cd(strItem,FALSE); | 277 | currentDir.cd(strItem,FALSE); |
271 | // qDebug("Path is "+strItem); | 278 | // qDebug("Path is "+strItem); |
272 | populateList(); | 279 | populateList(); |
273 | } else { | 280 | } else { |
274 | currentDir.cdUp(); | 281 | currentDir.cdUp(); |
275 | populateList(); | 282 | populateList(); |
276 | } | 283 | } |
277 | if(QDir(strItem).exists()){ | 284 | if(QDir(strItem).exists()){ |
278 | currentDir.cd(strItem, TRUE); | 285 | currentDir.cd(strItem, TRUE); |
279 | populateList(); | 286 | populateList(); |
280 | } | 287 | } |
281 | } else { | 288 | } else { |
282 | strItem=QDir::cleanDirPath(currentDir.canonicalPath()+"/"+strItem); | 289 | strItem=QDir::cleanDirPath(currentDir.canonicalPath()+"/"+strItem); |
283 | if( QFile::exists(strItem ) ) { | 290 | if( QFile::exists(strItem ) ) { |
284 | //currentDir.canonicalPath() | 291 | //currentDir.canonicalPath() |
285 | qDebug("We found our files!!"+strItem); | 292 | qDebug("We found our files!!"+strItem); |
286 | OnOK(); | 293 | OnOK(); |
287 | } | 294 | } |
288 | } //end not symlink | 295 | } //end not symlink |
289 | chdir(strItem.latin1()); | 296 | chdir(strItem.latin1()); |
290 | } | 297 | } |
291 | } | 298 | } |
292 | 299 | ||
293 | void fileBrowser::OnOK() | 300 | void fileBrowser::OnOK() |
294 | { | 301 | { |
295 | QListViewItemIterator it1( ListView); | 302 | QListViewItemIterator it1( ListView); |
296 | for ( ; it1.current(); ++it1 ) { | 303 | for ( ; it1.current(); ++it1 ) { |
297 | if ( it1.current()->isSelected() ) { | 304 | if ( it1.current()->isSelected() ) { |
298 | selectedFileName=QDir::cleanDirPath(currentDir.canonicalPath()+"/"+it1.current()->text(0)); | 305 | selectedFileName=QDir::cleanDirPath(currentDir.canonicalPath()+"/"+it1.current()->text(0)); |
299 | qDebug("selected filename is "+selectedFileName); | 306 | qDebug("selected filename is "+selectedFileName); |
300 | fileList.append( selectedFileName ); | 307 | fileList.append( selectedFileName ); |
301 | } | 308 | } |
302 | } | 309 | } |
303 | accept(); | 310 | accept(); |
304 | } | 311 | } |
305 | 312 | ||
306 | void fileBrowser::homeButtonPushed() { | 313 | void fileBrowser::homeButtonPushed() { |
307 | QString current = QDir::homeDirPath(); | 314 | QString current = QDir::homeDirPath(); |
308 | chdir( current.latin1() ); | 315 | chdir( current.latin1() ); |
309 | currentDir.cd( current, TRUE); | 316 | currentDir.cd( current, TRUE); |
310 | populateList(); | 317 | populateList(); |
311 | update(); | 318 | update(); |
312 | } | 319 | } |
313 | 320 | ||
314 | void fileBrowser::docButtonPushed() { | 321 | void fileBrowser::docButtonPushed() { |
315 | QString current = QPEApplication::documentDir(); | 322 | QString current = QPEApplication::documentDir(); |
316 | chdir( current.latin1() ); | 323 | chdir( current.latin1() ); |
317 | currentDir.cd( current, TRUE); | 324 | currentDir.cd( current, TRUE); |
318 | populateList(); | 325 | populateList(); |
319 | update(); | 326 | update(); |
320 | 327 | ||
321 | } | 328 | } |
322 | 329 | ||
323 | void fileBrowser::selectionChanged( const QString &select ) | 330 | void fileBrowser::selectionChanged( const QString &select ) |
324 | { | 331 | { |
325 | if ( select == "Documents") { | 332 | if ( select == "Documents") { |
326 | FileStack->raiseWidget( fileSelector ); | 333 | FileStack->raiseWidget( fileSelector ); |
327 | dirPathCombo->hide(); | 334 | dirPathCombo->hide(); |
328 | cdUpButton->hide(); | 335 | cdUpButton->hide(); |
329 | docButton->hide(); | 336 | docButton->hide(); |
330 | homeButton->hide(); | 337 | homeButton->hide(); |
331 | } else { | 338 | } else { |
332 | if ( select == "All files" ) | 339 | if ( select == "All files" ) |
333 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::All); | 340 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::All); |
334 | else | 341 | else |
335 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); | 342 | currentDir.setFilter( QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All); |
336 | 343 | ||
337 | populateList(); | 344 | populateList(); |
338 | update(); | 345 | update(); |
339 | dirPathCombo->show(); | 346 | dirPathCombo->show(); |
340 | cdUpButton->show(); | 347 | cdUpButton->show(); |
341 | docButton->show(); | 348 | docButton->show(); |
342 | homeButton->show(); | 349 | homeButton->show(); |
343 | FileStack->raiseWidget( ListView ); | 350 | FileStack->raiseWidget( ListView ); |
344 | } | 351 | } |
345 | } | 352 | } |
346 | 353 | ||
347 | void fileBrowser::docOpen( const DocLnk &doc ) | 354 | void fileBrowser::docOpen( const DocLnk &doc ) |
348 | { | 355 | { |
349 | fileList.append( doc.file().latin1() ); | 356 | fileList.append( doc.file().latin1() ); |
350 | accept(); | 357 | accept(); |
351 | } | 358 | } |
352 | 359 | ||
353 | void fileBrowser::ListPressed( int mouse, QListViewItem *item, const QPoint &point, int i) | 360 | void fileBrowser::ListPressed( int mouse, QListViewItem *item, const QPoint &point, int i) |
354 | { | 361 | { |
355 | switch (mouse) { | 362 | switch (mouse) { |
356 | case 1: | 363 | case 1: |
357 | break; | 364 | break; |
358 | case 2: | 365 | case 2: |
359 | showListMenu(item); | 366 | showListMenu(item); |
360 | break; | 367 | break; |
361 | }; | 368 | }; |
362 | } | 369 | } |
363 | 370 | ||
364 | void fileBrowser::showListMenu(QListViewItem *item) { | 371 | void fileBrowser::showListMenu(QListViewItem *item) { |
365 | 372 | ||
366 | QPopupMenu m;// = new QPopupMenu( Local_View ); | 373 | QPopupMenu m;// = new QPopupMenu( Local_View ); |
367 | if( item->text(0).find("/",0,TRUE)) | 374 | if( item->text(0).find("/",0,TRUE)) |
368 | m.insertItem( tr( "Change Directory" ), this, SLOT( doCd() )); | 375 | m.insertItem( tr( "Change Directory" ), this, SLOT( doCd() )); |
369 | else | 376 | else |
370 | m.insertItem( tr( "Make Directory" ), this, SLOT( makDir() )); | 377 | m.insertItem( tr( "Make Directory" ), this, SLOT( makDir() )); |
371 | m.insertItem( tr( "Rescan" ), this, SLOT( populateList()() )); | 378 | m.insertItem( tr( "Rescan" ), this, SLOT( populateList()() )); |
372 | m.insertItem( tr( "Rename" ), this, SLOT( localRename() )); | 379 | m.insertItem( tr( "Rename" ), this, SLOT( localRename() )); |
373 | m.insertSeparator(); | 380 | m.insertSeparator(); |
374 | m.insertItem( tr( "Delete" ), this, SLOT( localDelete() )); | 381 | m.insertItem( tr( "Delete" ), this, SLOT( localDelete() )); |
375 | m.exec( QCursor::pos() ); | 382 | m.exec( QCursor::pos() ); |
376 | 383 | ||
377 | } | 384 | } |
378 | 385 | ||
379 | void fileBrowser::doCd() { | 386 | void fileBrowser::doCd() { |
380 | listClicked( ListView->currentItem()); | 387 | listClicked( ListView->currentItem()); |
381 | } | 388 | } |
382 | 389 | ||
383 | void fileBrowser::makDir() { | 390 | void fileBrowser::makDir() { |
384 | InputDialog *fileDlg; | 391 | InputDialog *fileDlg; |
385 | fileDlg = new InputDialog(this,"Make Directory",TRUE, 0); | 392 | fileDlg = new InputDialog(this,"Make Directory",TRUE, 0); |
386 | fileDlg->exec(); | 393 | fileDlg->exec(); |
387 | if( fileDlg->result() == 1 ) { | 394 | if( fileDlg->result() == 1 ) { |
388 | QString filename = fileDlg->LineEdit1->text(); | 395 | QString filename = fileDlg->LineEdit1->text(); |
389 | currentDir.mkdir( currentDir.canonicalPath()+"/"+filename); | 396 | currentDir.mkdir( currentDir.canonicalPath()+"/"+filename); |
390 | } | 397 | } |
391 | populateList(); | 398 | populateList(); |
392 | } | 399 | } |
393 | 400 | ||
394 | void fileBrowser::localRename() { | 401 | void fileBrowser::localRename() { |
395 | QString curFile = ListView->currentItem()->text(0); | 402 | QString curFile = ListView->currentItem()->text(0); |
396 | InputDialog *fileDlg; | 403 | InputDialog *fileDlg; |
397 | fileDlg = new InputDialog(this,"Rename",TRUE, 0); | 404 | fileDlg = new InputDialog(this,"Rename",TRUE, 0); |
398 | fileDlg->inputText = curFile; | 405 | fileDlg->inputText = curFile; |
399 | fileDlg->exec(); | 406 | fileDlg->exec(); |
400 | if( fileDlg->result() == 1 ) { | 407 | if( fileDlg->result() == 1 ) { |
401 | QString oldname = currentDir.canonicalPath() + "/" + curFile; | 408 | QString oldname = currentDir.canonicalPath() + "/" + curFile; |
402 | QString newName = currentDir.canonicalPath() + "/" + fileDlg->LineEdit1->text();//+".playlist"; | 409 | QString newName = currentDir.canonicalPath() + "/" + fileDlg->LineEdit1->text();//+".playlist"; |
403 | if( rename(oldname.latin1(), newName.latin1())== -1) | 410 | if( rename(oldname.latin1(), newName.latin1())== -1) |
404 | QMessageBox::message("Note","Could not rename"); | 411 | QMessageBox::message("Note","Could not rename"); |
405 | } | 412 | } |
406 | populateList(); | 413 | populateList(); |
407 | } | 414 | } |
408 | 415 | ||
409 | void fileBrowser::localDelete() { | 416 | void fileBrowser::localDelete() { |
410 | QString f = ListView->currentItem()->text(0); | 417 | QString f = ListView->currentItem()->text(0); |
411 | if(QDir(f).exists() ) { | 418 | if(QDir(f).exists() ) { |
412 | switch ( QMessageBox::warning(this,"Delete","Do you really want to delete\n"+f+ | 419 | switch ( QMessageBox::warning(this,"Delete","Do you really want to delete\n"+f+ |
413 | " ?\nIt must be empty","Yes","No",0,0,1) ) { | 420 | " ?\nIt must be empty","Yes","No",0,0,1) ) { |
414 | case 0: { | 421 | case 0: { |
415 | f=currentDir.canonicalPath()+"/"+f; | 422 | f=currentDir.canonicalPath()+"/"+f; |
416 | QString cmd="rmdir "+f; | 423 | QString cmd="rmdir "+f; |
417 | system( cmd.latin1()); | 424 | system( cmd.latin1()); |
418 | populateList(); | 425 | populateList(); |
419 | } | 426 | } |
420 | break; | 427 | break; |
421 | case 1: | 428 | case 1: |
422 | // exit | 429 | // exit |
423 | break; | 430 | break; |
424 | }; | 431 | }; |
425 | 432 | ||
426 | } else { | 433 | } else { |
427 | switch ( QMessageBox::warning(this,"Delete","Do you really want to delete\n"+f | 434 | switch ( QMessageBox::warning(this,"Delete","Do you really want to delete\n"+f |
428 | +" ?","Yes","No",0,0,1) ) { | 435 | +" ?","Yes","No",0,0,1) ) { |
429 | case 0: { | 436 | case 0: { |
430 | f=currentDir.canonicalPath()+"/"+f; | 437 | f=currentDir.canonicalPath()+"/"+f; |
431 | QString cmd="rm "+f; | 438 | QString cmd="rm "+f; |
432 | system( cmd.latin1()); | 439 | system( cmd.latin1()); |
433 | populateList(); | 440 | populateList(); |
434 | } | 441 | } |
435 | break; | 442 | break; |
436 | case 1: | 443 | case 1: |
437 | // exit | 444 | // exit |
438 | break; | 445 | break; |
439 | }; | 446 | }; |
440 | } | 447 | } |
441 | } | 448 | } |
442 | 449 | ||
443 | void fileBrowser::updateMimeTypeMenu() { | 450 | void fileBrowser::updateMimeTypeMenu() { |
444 | 451 | ||
445 | disconnect( typemb, SIGNAL(selected(const QString&)), | 452 | disconnect( typemb, SIGNAL(selected(const QString&)), |
446 | this, SLOT(showType(const QString&)) ); | 453 | this, SLOT(showType(const QString&)) ); |
447 | 454 | ||
448 | QString prev; | 455 | QString prev; |
449 | 456 | ||
450 | // Type filter | 457 | // Type filter |
451 | QStringList types; | 458 | QStringList types; |
452 | types << tr("All"); | 459 | types << tr("All"); |
453 | types << "--"; | 460 | types << "--"; |
454 | types += getMimeTypes(); | 461 | types += getMimeTypes(); |
455 | prev = typemb->currentText(); | 462 | prev = typemb->currentText(); |
456 | typemb->clear(); | 463 | typemb->clear(); |
457 | typemb->insertItems(types); | 464 | typemb->insertItems(types); |
458 | // typemb->select(prev); | 465 | // typemb->select(prev); |
459 | 466 | ||
460 | connect(typemb, SIGNAL(selected(const QString&)), this, SLOT(showType(const QString&))); | 467 | connect(typemb, SIGNAL(selected(const QString&)), this, SLOT(showType(const QString&))); |
461 | } | 468 | } |
462 | 469 | ||
463 | void fileBrowser::showType(const QString &t) { | 470 | void fileBrowser::showType(const QString &t) { |
464 | 471 | ||
465 | qDebug(t); | 472 | qDebug(t); |
466 | mimeType = t+"/*"; | 473 | mimeType = t+"/*"; |
467 | // if(fileSelector) { | 474 | // if(fileSelector) { |
468 | // disconnect( fileSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( docOpen( const DocLnk & ) ) ); | 475 | // disconnect( fileSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( docOpen( const DocLnk & ) ) ); |
469 | // delete fileSelector; | 476 | // delete fileSelector; |
470 | // } | 477 | // } |
471 | // fileSelector = new FileSelector( mimeType, FileStack, "fileselector" , FALSE, FALSE); //buggy | 478 | // fileSelector = new FileSelector( mimeType, FileStack, "fileselector" , FALSE, FALSE); //buggy |
472 | // connect( fileSelector, SIGNAL( closeMe() ), this, SLOT( showEditTools() ) ); | 479 | // connect( fileSelector, SIGNAL( closeMe() ), this, SLOT( showEditTools() ) ); |
473 | // connect( fileSelector, SIGNAL( newSelected( const DocLnk &) ), this, SLOT( newFile( const DocLnk & ) ) ); | 480 | // connect( fileSelector, SIGNAL( newSelected( const DocLnk &) ), this, SLOT( newFile( const DocLnk & ) ) ); |
474 | // connect( fileSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( docOpen( const DocLnk & ) ) ); | 481 | // connect( fileSelector, SIGNAL( fileSelected( const DocLnk &) ), this, SLOT( docOpen( const DocLnk & ) ) ); |
475 | // fileSelector->reread(); | 482 | // fileSelector->reread(); |
476 | repaint(); | 483 | repaint(); |