-rw-r--r-- | libopie/ofileselector/ofiledialog.cpp | 4 | ||||
-rw-r--r-- | libopie/ofileselector/ofilelistview.cpp | 43 | ||||
-rw-r--r-- | libopie/ofileselector/ofileselector.cpp | 56 | ||||
-rw-r--r-- | libopie/ofileselector/ofileselector.h | 2 | ||||
-rw-r--r-- | libopie/ofileselector/ofileview.cpp | 3 | ||||
-rw-r--r-- | libopie/ofileselector/ofileview.h | 2 |
6 files changed, 69 insertions, 41 deletions
diff --git a/libopie/ofileselector/ofiledialog.cpp b/libopie/ofileselector/ofiledialog.cpp index 4783004..430def2 100644 --- a/libopie/ofileselector/ofiledialog.cpp +++ b/libopie/ofileselector/ofiledialog.cpp | |||
@@ -20,97 +20,97 @@ | |||
20 | -. .:....=;==+<; You should have received a copy of the GNU | 20 | -. .:....=;==+<; You should have received a copy of the GNU |
21 | -_. . . )=. = Library General Public License along with | 21 | -_. . . )=. = Library General Public License along with |
22 | -- :-=` this library; see the file COPYING.LIB. | 22 | -- :-=` this library; see the file COPYING.LIB. |
23 | If not, write to the Free Software Foundation, | 23 | If not, write to the Free Software Foundation, |
24 | Inc., 59 Temple Place - Suite 330, | 24 | Inc., 59 Temple Place - Suite 330, |
25 | Boston, MA 02111-1307, USA. | 25 | Boston, MA 02111-1307, USA. |
26 | 26 | ||
27 | */ | 27 | */ |
28 | 28 | ||
29 | #include <qpe/applnk.h> | 29 | #include <qpe/applnk.h> |
30 | #include <qstring.h> | 30 | #include <qstring.h> |
31 | #include <qapplication.h> | 31 | #include <qapplication.h> |
32 | #include <qlayout.h> | 32 | #include <qlayout.h> |
33 | 33 | ||
34 | #include "ofiledialog.h" | 34 | #include "ofiledialog.h" |
35 | 35 | ||
36 | OFileDialog::OFileDialog(const QString &caption, | 36 | OFileDialog::OFileDialog(const QString &caption, |
37 | QWidget *wid, int mode, int selector, | 37 | QWidget *wid, int mode, int selector, |
38 | const QString &dirName, | 38 | const QString &dirName, |
39 | const QString &fileName, | 39 | const QString &fileName, |
40 | const QMap<QString,QStringList>& mimetypes ) | 40 | const QMap<QString,QStringList>& mimetypes ) |
41 | : QDialog( wid, "OFileDialog", true ) | 41 | : QDialog( wid, "OFileDialog", true ) |
42 | { | 42 | { |
43 | // QVBoxLayout *lay = new QVBoxLayout(this); | 43 | // QVBoxLayout *lay = new QVBoxLayout(this); |
44 | //showMaximized(); | 44 | //showMaximized(); |
45 | QVBoxLayout *lay = new QVBoxLayout(this ); | 45 | QVBoxLayout *lay = new QVBoxLayout(this ); |
46 | file = new OFileSelector(this , mode, selector, | 46 | file = new OFileSelector(this , mode, selector, |
47 | dirName, fileName, | 47 | dirName, fileName, |
48 | mimetypes ); | 48 | mimetypes ); |
49 | lay->addWidget( file ); | 49 | lay->addWidget( file ); |
50 | 50 | ||
51 | //lay->addWidget( file ); | 51 | //lay->addWidget( file ); |
52 | //showFullScreen(); | 52 | //showFullScreen(); |
53 | setCaption( caption.isEmpty() ? tr("FileDialog") : caption ); | 53 | setCaption( caption.isEmpty() ? tr("FileDialog") : caption ); |
54 | connect(file, SIGNAL(fileSelected(const QString&) ), | 54 | connect(file, SIGNAL(fileSelected(const QString&) ), |
55 | this, SLOT(slotFileSelected(const QString&) ) ); | 55 | this, SLOT(slotFileSelected(const QString&) ) ); |
56 | 56 | ||
57 | connect(file, SIGNAL(dirSelected(const QString &) ), | 57 | connect(file, SIGNAL(dirSelected(const QString &) ), |
58 | this, SLOT(slotDirSelected(const QString &) ) ); | 58 | this, SLOT(slotDirSelected(const QString &) ) ); |
59 | 59 | ||
60 | 60 | ||
61 | file->setYesCancelVisible( false ); // relayout | 61 | file->setYesCancelVisible( false ); // relayout |
62 | } | 62 | } |
63 | QString OFileDialog::mimetype()const | 63 | QString OFileDialog::mimetype()const |
64 | { | 64 | { |
65 | return QString::null; | 65 | return QString::null; |
66 | } | 66 | } |
67 | QString OFileDialog::fileName()const | 67 | QString OFileDialog::fileName()const |
68 | { | 68 | { |
69 | return file->selectedName(); | 69 | return file->selectedName(); |
70 | } | 70 | } |
71 | DocLnk OFileDialog::selectedDocument()const | 71 | DocLnk OFileDialog::selectedDocument()const |
72 | { | 72 | { |
73 | return file->selectedDocument(); | 73 | return file->selectedDocument(); |
74 | } | 74 | } |
75 | QString OFileDialog::getOpenFileName(int selector, | 75 | QString OFileDialog::getOpenFileName(int selector, |
76 | const QString &startDir, | 76 | const QString &startDir, |
77 | const QString &file, | 77 | const QString &file, |
78 | const MimeTypes &mimes, | 78 | const MimeTypes &mimes, |
79 | QWidget *wid, | 79 | QWidget *wid, |
80 | const QString &caption ) | 80 | const QString &caption ) |
81 | { | 81 | { |
82 | QString ret; | 82 | QString ret; |
83 | OFileDialog dlg( caption.isEmpty() ? tr("Open") : caption, | 83 | OFileDialog dlg( caption.isEmpty() ? tr("Open") : caption, |
84 | wid, OFileSelector::OPEN, selector, startDir, file, mimes); | 84 | wid, OFileSelector::Open, selector, startDir, file, mimes); |
85 | dlg.showMaximized(); | 85 | dlg.showMaximized(); |
86 | if( dlg.exec() ) | 86 | if( dlg.exec() ) |
87 | ret = dlg.fileName(); | 87 | ret = dlg.fileName(); |
88 | 88 | ||
89 | return ret; | 89 | return ret; |
90 | } | 90 | } |
91 | QString OFileDialog::getSaveFileName(int selector, | 91 | QString OFileDialog::getSaveFileName(int selector, |
92 | const QString &startDir, | 92 | const QString &startDir, |
93 | const QString &file, | 93 | const QString &file, |
94 | const MimeTypes &mimes, | 94 | const MimeTypes &mimes, |
95 | QWidget *wid, | 95 | QWidget *wid, |
96 | const QString &caption ) | 96 | const QString &caption ) |
97 | { | 97 | { |
98 | QString ret; | 98 | QString ret; |
99 | OFileDialog dlg( caption.isEmpty() ? tr("Save") : caption, | 99 | OFileDialog dlg( caption.isEmpty() ? tr("Save") : caption, |
100 | wid, OFileSelector::SAVE, selector, startDir, file, mimes); | 100 | wid, OFileSelector::Save, selector, startDir, file, mimes); |
101 | dlg.showMaximized(); | 101 | dlg.showMaximized(); |
102 | if( dlg.exec() ) | 102 | if( dlg.exec() ) |
103 | ret = dlg.fileName(); | 103 | ret = dlg.fileName(); |
104 | 104 | ||
105 | return ret; | 105 | return ret; |
106 | } | 106 | } |
107 | 107 | ||
108 | void OFileDialog::slotFileSelected(const QString & ) | 108 | void OFileDialog::slotFileSelected(const QString & ) |
109 | { | 109 | { |
110 | accept(); | 110 | accept(); |
111 | } | 111 | } |
112 | void OFileDialog::slotDirSelected(const QString & ) | 112 | void OFileDialog::slotDirSelected(const QString & ) |
113 | { | 113 | { |
114 | // if mode | 114 | // if mode |
115 | //accept(); | 115 | //accept(); |
116 | } | 116 | } |
diff --git a/libopie/ofileselector/ofilelistview.cpp b/libopie/ofileselector/ofilelistview.cpp index 0c7d45b..7108a5b 100644 --- a/libopie/ofileselector/ofilelistview.cpp +++ b/libopie/ofileselector/ofilelistview.cpp | |||
@@ -1,118 +1,125 @@ | |||
1 | 1 | ||
2 | #include <qpe/mimetype.h> | ||
3 | #include <qpe/resource.h> | ||
4 | |||
2 | #include "ofileselector.h" | 5 | #include "ofileselector.h" |
3 | #include "ofileselectoritem.h" | 6 | #include "ofileselectoritem.h" |
4 | #include "ofilelistview.h" | 7 | #include "ofilelistview.h" |
5 | 8 | ||
6 | 9 | ||
7 | OFileListView::OFileListView( QWidget* parent, OFileSelector* sel) | 10 | OFileListView::OFileListView( QWidget* parent, OFileSelector* sel) |
8 | : QListView( parent ), OFileView( sel ) | 11 | : QListView( parent ), OFileView( sel ) |
9 | { | 12 | { |
10 | 13 | ||
11 | } | 14 | } |
12 | OFileListView::~OFileListView() { | 15 | OFileListView::~OFileListView() { |
13 | 16 | ||
14 | } | 17 | } |
15 | void OFileListView::clear() { | 18 | void OFileListView::clear() { |
16 | QListView::clear(); | 19 | QListView::clear(); |
17 | } | 20 | } |
18 | void OFileListView::addFile( const QString& mime, | 21 | void OFileListView::addFile( const QString&, |
19 | QFileInfo* info, | 22 | QFileInfo* info, |
20 | bool isSymlink ) { | 23 | bool isSymlink ) { |
21 | MimeType type( info->absFilePath() ); | 24 | MimeType type( info->absFilePath() ); |
22 | QPixmap pix = type.pixmap(); | 25 | QPixmap pix = type.pixmap(); |
23 | QString dir; | 26 | QString dir; |
24 | QString name; | 27 | QString name; |
25 | bool locked = false; | 28 | bool locked = false; |
26 | 29 | ||
27 | if( pix.isNull() ) | 30 | if( pix.isNull() ) |
28 | pix = Resource::loadPixmap( "UnknownDocument-14"); | 31 | pix = Resource::loadPixmap( "UnknownDocument-14"); |
29 | 32 | ||
30 | dir = info->dirPath( true ); | 33 | dir = info->dirPath( true ); |
31 | 34 | ||
32 | if( isSymlink ) | 35 | if( isSymlink ) |
33 | name = info->fileName() + " -> " +info->dirPath() + "/" + info->readLink(); | 36 | name = info->fileName() + " -> " +info->dirPath() + "/" + info->readLink(); |
34 | else { | 37 | else { |
35 | name = info->fileName(); | 38 | name = info->fileName(); |
36 | if( ( selector()->mode() == Open && !info->isReadable() )|| | 39 | if( ( selector()->mode() == OFileSelector::Open && !info->isReadable() ) || |
37 | ( selector()->mode() == Save && !info->isWritable() ) ){ | 40 | ( selector()->mode() == OFileSelector::Save && !info->isWritable() ) ){ |
38 | 41 | ||
39 | locked = true; pix = Resource::loadPixmap("locked"); | 42 | locked = true; pix = Resource::loadPixmap("locked"); |
40 | } | 43 | } |
41 | } | 44 | } |
42 | new OFileSelectorItem( this, pix, name, | 45 | new OFileSelectorItem( this, pix, name, |
43 | info->lastModified().toString(), | 46 | info->lastModified().toString(), |
44 | QString::number( info->size() ), | 47 | QString::number( info->size() ), |
45 | dir, locked ); | 48 | dir, locked ); |
46 | } | 49 | } |
47 | void OFileListView::addFile( const QString& /*mime*/, const QString& /*dir*/, | 50 | void OFileListView::addFile( const QString& /*mime*/, const QString& /*dir*/, |
48 | const QString& /*file*/, bool /*isSyml*/ ) { | 51 | const QString& /*file*/, bool /*isSyml*/ ) { |
49 | 52 | ||
50 | } | 53 | } |
51 | void OFileListView::addDir( const QString& mime, | 54 | void OFileListView::addDir( const QString&, |
52 | QFileInfo* info, bool isSym ) { | 55 | QFileInfo* info, bool symlink ) { |
53 | 56 | ||
54 | bool locked = false; | 57 | bool locked = false; |
55 | QString name; | 58 | QString name; |
56 | QPixmap pix; | 59 | QPixmap pix; |
57 | 60 | ||
58 | if( ( selector()->mode() == Open && !info->isReadable() ) || | 61 | if( ( selector()->mode() == OFileSelector::Open && !info->isReadable() ) || |
59 | ( selector()->mode() == Save && !info->isWritable() ) ){ | 62 | ( selector()->mode() == OFileSelector::Save && !info->isWritable() ) ){ |
60 | 63 | ||
61 | locked = true; | 64 | locked = true; |
62 | 65 | ||
63 | if( symlink ) | 66 | if( symlink ) |
64 | pix = selector()->pixmap("symlinkedlocked"); | 67 | pix = selector()->pixmap("symlinkedlocked"); |
65 | else | 68 | else |
66 | pix = Resource::loadPixmap("lockedfolder"); | 69 | pix = Resource::loadPixmap("lockedfolder"); |
67 | 70 | ||
68 | }else { // readable | 71 | }else { // readable |
69 | pix = symlink ? selector()->pixmap("dirsymlink") : Resource::loadPixmap("folder") ; | 72 | pix = symlink ? selector()->pixmap("dirsymlink") : Resource::loadPixmap("folder") ; |
70 | } | 73 | } |
71 | 74 | ||
72 | name = symlink ? info->fileName() + "->" + info->dirPath(true) + "/" +info->readLink() : info->fileName() ; | 75 | name = symlink ? info->fileName() + "->" + info->dirPath(true) + "/" +info->readLink() : info->fileName() ; |
73 | 76 | ||
74 | new OFileSelectorItem( this, pix, name, | 77 | new OFileSelectorItem( this, pix, name, |
75 | info->lastModified().toString(), | 78 | info->lastModified().toString(), |
76 | QString::number( info->size() ), | 79 | QString::number( info->size() ), |
77 | info->dirPath( true ), locked, | 80 | info->dirPath( true ), locked, |
78 | true ); | 81 | true ); |
79 | 82 | ||
80 | } | 83 | } |
81 | void OFileListView::addDir( const QString& mime, const QString& dir, | 84 | void OFileListView::addDir( const QString& /*mime*/, const QString& /*dir*/, |
82 | const QString& file, bool ) { | 85 | const QString& /*file*/, bool ) { |
83 | 86 | ||
84 | } | 87 | } |
85 | void OFileListView::addSymlink( const QString& mime, | 88 | void OFileListView::addSymlink( const QString& /*mime*/, |
86 | QFileInfo* info, | 89 | QFileInfo* /*info*/, |
87 | bool isSym ) { | 90 | bool /*isSym*/ ) { |
88 | 91 | ||
89 | } | 92 | } |
90 | void OFileListView::addSymlink( const QString& mime, const QString& path, | 93 | void OFileListView::addSymlink( const QString& /*mime*/, const QString& /*path*/, |
91 | const QString& file, bool isSym ) { | 94 | const QString& /*file*/, bool /*isSym*/ ) { |
92 | 95 | ||
93 | } | 96 | } |
94 | void OFileListView::cd( const QString& ) { | 97 | void OFileListView::cd( const QString& ) { |
95 | 98 | ||
96 | } | 99 | } |
97 | QWidget* OFileListView::widget() { | 100 | QWidget* OFileListView::widget() { |
98 | return this; | 101 | return this; |
99 | } | 102 | } |
100 | QString OFileListView::selectedName()const{ | 103 | QString OFileListView::selectedName()const{ |
101 | QListViewItem *item = currentItem(); | 104 | QListViewItem *item = currentItem(); |
102 | if (!item ) | 105 | if (!item ) |
103 | return QString::null; | 106 | return QString::null; |
104 | 107 | ||
105 | return item->text( 1 ); | 108 | return item->text( 1 ); |
106 | } | 109 | } |
107 | QStringList OFileListView::selectedNames()const { | 110 | QStringList OFileListView::selectedNames()const { |
108 | 111 | QStringList list; | |
112 | list << selectedName(); | ||
113 | return list; | ||
109 | } | 114 | } |
110 | QString OFileListView::selectedPath()const { | 115 | QString OFileListView::selectedPath()const { |
111 | 116 | return QString::null; | |
112 | } | 117 | } |
113 | QString OFileListView::selectedPaths()const { | 118 | QStringList OFileListView::selectedPaths()const { |
114 | 119 | QStringList list; | |
120 | list << selectedPath(); | ||
121 | return list; | ||
115 | } | 122 | } |
116 | int OFileListView::fileCount() { | 123 | int OFileListView::fileCount() { |
117 | return childCount(); | 124 | return childCount(); |
118 | } | 125 | } |
diff --git a/libopie/ofileselector/ofileselector.cpp b/libopie/ofileselector/ofileselector.cpp index f655606..16ee3ee 100644 --- a/libopie/ofileselector/ofileselector.cpp +++ b/libopie/ofileselector/ofileselector.cpp | |||
@@ -185,287 +185,288 @@ void OFileSelector::setLineEditVisible( bool show ) | |||
185 | m_boxName->hide(); | 185 | m_boxName->hide(); |
186 | } | 186 | } |
187 | } | 187 | } |
188 | m_shLne = show; | 188 | m_shLne = show; |
189 | } | 189 | } |
190 | 190 | ||
191 | void OFileSelector::setChooserVisible( bool show ) | 191 | void OFileSelector::setChooserVisible( bool show ) |
192 | { | 192 | { |
193 | m_shChooser = show; | 193 | m_shChooser = show; |
194 | initializeChooser(); | 194 | initializeChooser(); |
195 | if( m_shChooser ){ | 195 | if( m_shChooser ){ |
196 | m_boxView->hide(); | 196 | m_boxView->hide(); |
197 | }else{ | 197 | }else{ |
198 | m_boxView->show(); | 198 | m_boxView->show(); |
199 | } | 199 | } |
200 | } | 200 | } |
201 | 201 | ||
202 | QCheckBox* OFileSelector::permissionCheckbox() | 202 | QCheckBox* OFileSelector::permissionCheckbox() |
203 | { | 203 | { |
204 | if( m_selector == Normal ) | 204 | if( m_selector == Normal ) |
205 | return 0l; | 205 | return 0l; |
206 | else | 206 | else |
207 | return m_checkPerm; | 207 | return m_checkPerm; |
208 | } | 208 | } |
209 | bool OFileSelector::setPermission()const | 209 | bool OFileSelector::setPermission()const |
210 | { | 210 | { |
211 | return m_checkPerm == 0 ? false : m_checkPerm->isChecked(); | 211 | return m_checkPerm == 0 ? false : m_checkPerm->isChecked(); |
212 | } | 212 | } |
213 | void OFileSelector::setPermissionChecked( bool check ) | 213 | void OFileSelector::setPermissionChecked( bool check ) |
214 | { | 214 | { |
215 | if( m_checkPerm ) | 215 | if( m_checkPerm ) |
216 | m_checkPerm->setChecked( check ); | 216 | m_checkPerm->setChecked( check ); |
217 | } | 217 | } |
218 | 218 | ||
219 | void OFileSelector::setMode(int mode) // FIXME do direct raising | 219 | void OFileSelector::setMode(int mode) // FIXME do direct raising |
220 | { | 220 | { |
221 | m_mode = mode; | 221 | m_mode = mode; |
222 | if( m_selector == Normal ) | 222 | if( m_selector == Normal ) |
223 | return; | 223 | return; |
224 | } | 224 | } |
225 | void OFileSelector::setShowDirs(bool ) | 225 | void OFileSelector::setShowDirs(bool ) |
226 | { | 226 | { |
227 | m_dir = true; | 227 | m_dir = true; |
228 | reparse(); | 228 | reparse(); |
229 | } | 229 | } |
230 | void OFileSelector::setCaseSensetive(bool caSe ) | 230 | void OFileSelector::setCaseSensetive(bool caSe ) |
231 | { | 231 | { |
232 | m_case = caSe; | 232 | m_case = caSe; |
233 | reparse(); | 233 | reparse(); |
234 | } | 234 | } |
235 | void OFileSelector::setShowFiles(bool show ) | 235 | void OFileSelector::setShowFiles(bool show ) |
236 | { | 236 | { |
237 | m_files = show; | 237 | m_files = show; |
238 | reparse(); | 238 | reparse(); |
239 | } | 239 | } |
240 | /// | 240 | /// |
241 | bool OFileSelector::cd(const QString &path ) | 241 | bool OFileSelector::cd(const QString &path ) |
242 | { | 242 | { |
243 | m_currentDir = path; | 243 | m_currentDir = path; |
244 | reparse(); | 244 | reparse(); |
245 | return true; | 245 | return true; |
246 | } | 246 | } |
247 | void OFileSelector::setSelector(int mode ) | 247 | void OFileSelector::setSelector(int mode ) |
248 | { | 248 | { |
249 | QString text; | 249 | QString text; |
250 | switch( mode ){ | 250 | switch( mode ){ |
251 | case Normal: | 251 | case Normal: |
252 | text = tr("Documents"); | 252 | text = tr("Documents"); |
253 | break; | 253 | break; |
254 | case Extended: | 254 | case Extended: |
255 | text = tr("Files"); | 255 | text = tr("Files"); |
256 | break; | 256 | break; |
257 | case ExtendedAll: | 257 | case ExtendedAll: |
258 | text = tr("All Files"); | 258 | text = tr("All Files"); |
259 | break; | 259 | break; |
260 | } | 260 | } |
261 | slotViewCheck( text ); | 261 | slotViewCheck( text ); |
262 | } | 262 | } |
263 | 263 | ||
264 | void OFileSelector::setPopupFactory(OPopupMenuFactory *popup ) | 264 | void OFileSelector::setPopupFactory(OPopupMenuFactory */*popup*/ ) |
265 | { | 265 | { |
266 | /* m_custom = popup; | 266 | /* m_custom = popup; |
267 | m_showPopup = true; | 267 | m_showPopup = true; |
268 | */ | 268 | */ |
269 | } | 269 | } |
270 | 270 | ||
271 | //void OFileSelector::updateL | 271 | //void OFileSelector::updateL |
272 | 272 | ||
273 | QString OFileSelector::selectedName() const | 273 | QString OFileSelector::selectedName() const |
274 | { | 274 | { |
275 | QString name; | 275 | QString name; |
276 | if( m_selector == Normal ){ | 276 | if( m_selector == Normal ){ |
277 | DocLnk lnk = m_select->selectedDocument(); | 277 | DocLnk lnk = m_select->selectedDocument(); |
278 | name = lnk.file(); | 278 | name = lnk.file(); |
279 | }else if( m_selector == Extended || m_selector == ExtendedAll ){ | 279 | }else { |
280 | if ( m_shLne ) { | 280 | if ( m_shLne ) { |
281 | name = m_currentDir + "/" +m_edit->text(); | 281 | name = m_currentDir + "/" +m_edit->text(); |
282 | }else{ | 282 | }else{ |
283 | name = m_currentDir + "/" + currentView()->selectedName(); | 283 | name = m_currentDir + "/" + currentView()->selectedName(); |
284 | } | 284 | } |
285 | } | 285 | } |
286 | return name; | 286 | return name; |
287 | } | 287 | } |
288 | QStringList OFileSelector::selectedNames()const | 288 | QStringList OFileSelector::selectedNames()const |
289 | { | 289 | { |
290 | QStringList list; | 290 | QStringList list; |
291 | if( m_selector == Normal ){ | 291 | if( m_selector == Normal ){ |
292 | list << selectedName(); | 292 | list << selectedName(); |
293 | }else { | 293 | }else { |
294 | list << selectedName(); // FIXME implement multiple Selections | 294 | list << selectedName(); // FIXME implement multiple Selections |
295 | } | 295 | } |
296 | return list; | 296 | return list; |
297 | } | 297 | } |
298 | /** If mode is set to the Dir selection this will return the selected path. | 298 | /** If mode is set to the Dir selection this will return the selected path. |
299 | * | 299 | * |
300 | * | 300 | * |
301 | */ | 301 | */ |
302 | QString OFileSelector::selectedPath()const | 302 | QString OFileSelector::selectedPath()const |
303 | { | 303 | { |
304 | QString path; | 304 | QString path; |
305 | if( m_selector == Normal ){ | 305 | if( m_selector == Normal ){ |
306 | path = QPEApplication::documentDir(); | 306 | path = QPEApplication::documentDir(); |
307 | }else if( m_selector == Extended || m_selector == ExtendedAll ){ | 307 | } /*else if( m_selector == Extended || m_selector == ExtendedAll ){ |
308 | ; //FIXME | 308 | ; |
309 | } | 309 | }*/ |
310 | return path; | 310 | return path; |
311 | } | 311 | } |
312 | QStringList OFileSelector::selectedPaths() const | 312 | QStringList OFileSelector::selectedPaths() const |
313 | { | 313 | { |
314 | QStringList list; | 314 | QStringList list; |
315 | list << selectedPath(); | 315 | list << selectedPath(); |
316 | return list; | 316 | return list; |
317 | } | 317 | } |
318 | QString OFileSelector::directory()const | 318 | QString OFileSelector::directory()const |
319 | { | 319 | { |
320 | if( m_selector == Normal ) | 320 | if( m_selector == Normal ) |
321 | return QPEApplication::documentDir(); | 321 | return QPEApplication::documentDir(); |
322 | 322 | ||
323 | return QDir(m_currentDir).absPath(); | 323 | return QDir(m_currentDir).absPath(); |
324 | } | 324 | } |
325 | 325 | ||
326 | int OFileSelector::fileCount() | 326 | int OFileSelector::fileCount() |
327 | { | 327 | { |
328 | int count; | 328 | int count; |
329 | switch( m_selector ){ | 329 | switch( m_selector ){ |
330 | case Normal: | 330 | case Normal: |
331 | count = m_select->fileCount(); | 331 | count = m_select->fileCount(); |
332 | break; | 332 | break; |
333 | case Extended: | 333 | case Extended: |
334 | case ExtendedAll: | 334 | case ExtendedAll: |
335 | default: | 335 | default: |
336 | count = currentView()->childCount(); | 336 | count = currentView()->fileCount(); |
337 | break; | 337 | break; |
338 | } | 338 | } |
339 | return count; | 339 | return count; |
340 | } | 340 | } |
341 | DocLnk OFileSelector::selectedDocument() const | 341 | DocLnk OFileSelector::selectedDocument() const |
342 | { | 342 | { |
343 | DocLnk lnk; | 343 | DocLnk lnk; |
344 | switch( m_selector ){ | 344 | switch( m_selector ){ |
345 | case Normal:{ | 345 | case Normal:{ |
346 | lnk = m_select->selectedDocument(); | 346 | lnk = m_select->selectedDocument(); |
347 | break; | 347 | break; |
348 | } | 348 | } |
349 | case Extended: | 349 | case Extended: |
350 | case ExtendedAll: | 350 | case ExtendedAll: |
351 | default: | 351 | default: |
352 | lnk = DocLnk( selectedName() ); // new DocLnk | 352 | lnk = DocLnk( selectedName() ); |
353 | break; | 353 | break; |
354 | } | 354 | } |
355 | return lnk; | 355 | return lnk; |
356 | } | 356 | } |
357 | QValueList<DocLnk> OFileSelector::selectedDocuments() const | 357 | QValueList<DocLnk> OFileSelector::selectedDocuments() const |
358 | { | 358 | { |
359 | QValueList<DocLnk> docs; | 359 | QValueList<DocLnk> docs; |
360 | docs.append( selectedDocument() ); | 360 | docs.append( selectedDocument() ); |
361 | return docs; | 361 | return docs; |
362 | } | 362 | } |
363 | 363 | ||
364 | 364 | ||
365 | // slots internal | 365 | // slots internal |
366 | 366 | ||
367 | void OFileSelector::slotOk() | 367 | void OFileSelector::slotOk() |
368 | { | 368 | { |
369 | emit ok(); | 369 | emit ok(); |
370 | } | 370 | } |
371 | void OFileSelector::slotCancel() | 371 | void OFileSelector::slotCancel() |
372 | { | 372 | { |
373 | emit cancel(); | 373 | emit cancel(); |
374 | } | 374 | } |
375 | /* switch the views */ | ||
375 | void OFileSelector::slotViewCheck(const QString &sel) | 376 | void OFileSelector::slotViewCheck(const QString &sel) |
376 | { | 377 | { |
377 | if( sel == tr("Documents" ) ){ | 378 | if( sel == tr("Documents" ) ){ |
378 | if( m_select == 0 ){ | 379 | if( m_select == 0 ){ |
379 | // autMime? fix cause now we use All and not the current | 380 | // autMime? fix cause now we use All and not the current |
380 | // yes currentMime fixes that for us | 381 | // yes currentMime fixes that for us |
381 | QString mime = currentMimeType(); | 382 | QString mime = currentMimeType(); |
382 | m_select = new FileSelector(mime, | 383 | m_select = new FileSelector(mime, |
383 | m_stack, "fileselector", | 384 | m_stack, "fileselector", |
384 | m_shNew, m_shClose); | 385 | m_shNew, m_shClose); |
385 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), | 386 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), |
386 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); | 387 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); |
387 | connect(m_select, SIGNAL(closeMe() ), | 388 | connect(m_select, SIGNAL(closeMe() ), |
388 | this, SIGNAL(closeMe() ) ); | 389 | this, SIGNAL(closeMe() ) ); |
389 | //connect to close me and other signals as well | 390 | //connect to close me and other signals as well |
390 | 391 | ||
391 | m_stack->addWidget( m_select, Normal ); | 392 | m_stack->addWidget( m_select, Normal ); |
392 | } | 393 | } |
393 | m_stack->raiseWidget( Normal ); | 394 | m_stack->raiseWidget( Normal ); |
394 | m_selector = Normal; | 395 | m_selector = Normal; |
395 | }else if( sel == tr("Files") ){ | 396 | }else if( sel == tr("Files") ){ |
396 | m_selector = Extended; | 397 | m_selector = Extended; |
397 | initializeListView(); | 398 | initializeListView(); |
398 | reparse(); | 399 | reparse(); |
399 | m_stack->raiseWidget( Extended ); | 400 | m_stack->raiseWidget( Extended ); |
400 | }else if( sel == tr("All Files") ){ | 401 | }else if( sel == tr("All Files") ){ |
401 | m_selector = ExtendedAll; | 402 | m_selector = ExtendedAll; |
402 | initializeListView(); | 403 | initializeListView(); |
403 | reparse(); | 404 | reparse(); |
404 | m_stack->raiseWidget( Extended ); // same widget other QFileFilter | 405 | m_stack->raiseWidget( Extended ); // same widget other QFileFilter |
405 | } | 406 | } |
406 | } | 407 | } |
407 | // not yet finished..... | 408 | |
408 | QString OFileSelector::currentMimeType() const{ | 409 | QString OFileSelector::currentMimeType() const{ |
409 | QString mime; | 410 | QString mime; |
410 | QString currentText; | 411 | QString currentText; |
411 | if (m_shChooser ) | 412 | if (m_shChooser ) |
412 | currentText = m_mimeCheck->currentText(); | 413 | currentText = m_mimeCheck->currentText(); |
413 | 414 | ||
414 | if (tr("All") == currentText ) return QString::null; | 415 | if (tr("All") == currentText ) return QString::null; |
415 | else if (currentText.isEmpty() ) { | 416 | else if (currentText.isEmpty() ) { |
416 | ; | 417 | ; |
417 | }else { | 418 | }else { |
418 | QMap<QString, QStringList>::ConstIterator it; | 419 | QMap<QString, QStringList>::ConstIterator it; |
419 | it = m_mimetypes.find( currentText ); | 420 | it = m_mimetypes.find( currentText ); |
420 | if ( it == m_mimetypes.end() ) { | 421 | if ( it == m_mimetypes.end() ) { |
421 | mime = it.data().join(";"); | 422 | mime = it.data().join(";"); |
422 | }else{ | 423 | }else{ |
423 | mime = currentText; | 424 | mime = currentText; |
424 | } | 425 | } |
425 | } | 426 | } |
426 | return mime; | 427 | return mime; |
427 | } | 428 | } |
428 | void OFileSelector::slotMimeCheck(const QString &mime) | 429 | void OFileSelector::slotMimeCheck(const QString &mime) |
429 | { | 430 | { |
430 | if( m_selector == Normal ){ | 431 | if( m_selector == Normal ){ |
431 | //if( m_autoMime ){ | 432 | //if( m_autoMime ){ |
432 | QString newMimeType; | 433 | QString newMimeType; |
433 | if (mime != tr("All") ) { | 434 | if (mime != tr("All") ) { |
434 | QMap<QString, QStringList>::Iterator it; | 435 | QMap<QString, QStringList>::Iterator it; |
435 | it = m_mimetypes.find(mime); | 436 | it = m_mimetypes.find(mime); |
436 | if ( it != m_mimetypes.end() ) { | 437 | if ( it != m_mimetypes.end() ) { |
437 | newMimeType = it.data().join(";"); | 438 | newMimeType = it.data().join(";"); |
438 | }else{ | 439 | }else{ |
439 | newMimeType = mime; | 440 | newMimeType = mime; |
440 | } | 441 | } |
441 | } | 442 | } |
442 | delete m_select; | 443 | delete m_select; |
443 | m_select = new FileSelector( newMimeType, | 444 | m_select = new FileSelector( newMimeType, |
444 | m_stack, "fileselector", | 445 | m_stack, "fileselector", |
445 | m_shNew, m_shClose); | 446 | m_shNew, m_shClose); |
446 | 447 | ||
447 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), | 448 | connect(m_select, SIGNAL(fileSelected( const DocLnk & ) ), |
448 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); | 449 | this, SLOT( slotFileBridgeSelected(const DocLnk & ) ) ); |
449 | connect(m_select, SIGNAL(closeMe() ), | 450 | connect(m_select, SIGNAL(closeMe() ), |
450 | this, SIGNAL(closeMe() ) ); | 451 | this, SIGNAL(closeMe() ) ); |
451 | //connect to close me and other signals as well | 452 | //connect to close me and other signals as well |
452 | m_stack->addWidget( m_select, Normal ); | 453 | m_stack->addWidget( m_select, Normal ); |
453 | m_stack->raiseWidget( Normal ); | 454 | m_stack->raiseWidget( Normal ); |
454 | updateMimes(); | 455 | updateMimes(); |
455 | updateMimeCheck(); | 456 | updateMimeCheck(); |
456 | m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); | 457 | m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); |
457 | //} | 458 | //} |
458 | }else{ // others | 459 | }else{ // others |
459 | qWarning("Mime %s", mime.latin1() ); | 460 | qWarning("Mime %s", mime.latin1() ); |
460 | if(m_shChooser ){ | 461 | if(m_shChooser ){ |
461 | qWarning("Current Text %s", m_mimeCheck->currentText().latin1() ); | 462 | qWarning("Current Text %s", m_mimeCheck->currentText().latin1() ); |
462 | //m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); | 463 | //m_mimeCheck->setCurrentItem(indexByString( m_mimeCheck, mime) ); |
463 | } | 464 | } |
464 | reparse(); | 465 | reparse(); |
465 | } | 466 | } |
466 | 467 | ||
467 | } | 468 | } |
468 | /* | 469 | /* |
469 | * Ok if a non dir gets inserted into this combobox | 470 | * Ok if a non dir gets inserted into this combobox |
470 | * we need to change it | 471 | * we need to change it |
471 | * QFileInfo and dirPath will give us the right Dir | 472 | * QFileInfo and dirPath will give us the right Dir |
@@ -570,140 +571,140 @@ void OFileSelector::updateMimes() | |||
570 | m_mimetypes.clear(); | 571 | m_mimetypes.clear(); |
571 | m_mimetypes.insert( tr("All"), QString::null ); | 572 | m_mimetypes.insert( tr("All"), QString::null ); |
572 | if( m_selector == Normal ){ | 573 | if( m_selector == Normal ){ |
573 | DocLnkSet set; | 574 | DocLnkSet set; |
574 | Global::findDocuments(&set, QString::null ); | 575 | Global::findDocuments(&set, QString::null ); |
575 | QListIterator<DocLnk> dit( set.children() ); | 576 | QListIterator<DocLnk> dit( set.children() ); |
576 | for( ; dit.current(); ++dit ){ | 577 | for( ; dit.current(); ++dit ){ |
577 | if( !m_mimetypes.contains( (*dit)->type() ) ) | 578 | if( !m_mimetypes.contains( (*dit)->type() ) ) |
578 | m_mimetypes.insert( (*dit)->type(), (*dit)->type() ); | 579 | m_mimetypes.insert( (*dit)->type(), (*dit)->type() ); |
579 | } | 580 | } |
580 | }// else done in reparse | 581 | }// else done in reparse |
581 | } | 582 | } |
582 | } | 583 | } |
583 | void OFileSelector::initVars() | 584 | void OFileSelector::initVars() |
584 | { | 585 | { |
585 | if( m_mimetypes.isEmpty() ) | 586 | if( m_mimetypes.isEmpty() ) |
586 | m_autoMime = true; | 587 | m_autoMime = true; |
587 | else | 588 | else |
588 | m_autoMime = false; | 589 | m_autoMime = false; |
589 | 590 | ||
590 | m_shClose = false; | 591 | m_shClose = false; |
591 | m_shNew = false; | 592 | m_shNew = false; |
592 | m_shTool = true; | 593 | m_shTool = true; |
593 | m_shPerm = false; | 594 | m_shPerm = false; |
594 | m_shLne = true; | 595 | m_shLne = true; |
595 | m_shChooser = true; | 596 | m_shChooser = true; |
596 | m_shYesNo = true; | 597 | m_shYesNo = true; |
597 | m_case = false; | 598 | m_case = false; |
598 | m_dir = true; | 599 | m_dir = true; |
599 | m_files = true; | 600 | m_files = true; |
600 | m_showPopup = false; | 601 | m_showPopup = false; |
601 | 602 | ||
602 | if(m_pixmaps == 0 ) // init the pixmaps | 603 | if(m_pixmaps == 0 ) // init the pixmaps |
603 | initPics(); | 604 | initPics(); |
604 | 605 | ||
605 | // pointers | 606 | // pointers |
606 | m_location = 0; | 607 | m_location = 0; |
607 | m_mimeCheck = 0; | 608 | m_mimeCheck = 0; |
608 | m_viewCheck = 0; | 609 | m_viewCheck = 0; |
609 | m_homeButton = 0; | 610 | m_homeButton = 0; |
610 | m_docButton = 0; | 611 | m_docButton = 0; |
611 | m_hideButton = 0; | 612 | m_hideButton = 0; |
612 | m_ok = 0; | 613 | m_ok = 0; |
613 | m_cancel = 0; | 614 | m_cancel = 0; |
614 | m_reread = 0; | 615 | m_reread = 0; |
615 | m_up = 0; | 616 | m_up = 0; |
616 | m_View = 0; | 617 | m_View = 0; |
617 | m_checkPerm = 0; | 618 | m_checkPerm = 0; |
618 | m_pseudo = 0; | 619 | m_pseudo = 0; |
619 | m_pseudoLayout = 0; | 620 | m_pseudoLayout = 0; |
620 | m_select = 0; | 621 | m_select = 0; |
621 | m_stack = 0; | 622 | m_stack = 0; |
622 | m_lay = 0; | 623 | m_lay = 0; |
623 | m_Oselector = 0; | 624 | m_Oselector = 0; |
624 | m_boxToolbar = 0; | 625 | m_boxToolbar = 0; |
625 | m_boxOk = 0; | 626 | m_boxOk = 0; |
626 | m_boxName = 0; | 627 | m_boxName = 0; |
627 | m_boxView = 0; | 628 | m_boxView = 0; |
628 | m_custom = 0; | 629 | m_custom = 0; |
629 | m_edit = 0; | 630 | m_edit = 0; |
630 | m_fnLabel = 0; | 631 | m_fnLabel = 0; |
631 | m_new = 0; | 632 | m_new = 0; |
632 | m_close = 0; | 633 | m_close = 0; |
633 | } | 634 | } |
634 | void OFileSelector::addFile(const QString &mime, QFileInfo *info, bool symlink) | 635 | void OFileSelector::addFile(const QString &, QFileInfo *info, bool ) |
635 | { | 636 | { |
636 | if(!m_files) | 637 | if(!m_files) |
637 | return; | 638 | return; |
638 | // if( !compliesMime(info->absFilePath(), mime ) ) | 639 | // if( !compliesMime(info->absFilePath(), mime ) ) |
639 | // return; | 640 | // return; |
640 | MimeType type( info->absFilePath() ); | 641 | MimeType type( info->absFilePath() ); |
641 | if (!compliesMime( type.id() ) ) | 642 | if (!compliesMime( type.id() ) ) |
642 | return; | 643 | return; |
643 | 644 | ||
644 | } | 645 | } |
645 | void OFileSelector::addDir(const QString &mime, QFileInfo *info, bool symlink ) | 646 | void OFileSelector::addDir(const QString &, QFileInfo *, bool ) |
646 | { | 647 | { |
647 | if(!m_dir) | 648 | if(!m_dir) |
648 | return; | 649 | return; |
649 | } | 650 | } |
650 | void OFileSelector::delItems() | 651 | void OFileSelector::delItems() |
651 | { | 652 | { |
652 | 653 | ||
653 | } | 654 | } |
654 | void OFileSelector::initializeName() | 655 | void OFileSelector::initializeName() |
655 | { | 656 | { |
656 | /** Name Layout Line | 657 | /** Name Layout Line |
657 | * This is the Layout line arranged in | 658 | * This is the Layout line arranged in |
658 | * horizontal way each components | 659 | * horizontal way each components |
659 | * are next to each other | 660 | * are next to each other |
660 | * but we will only do this if | 661 | * but we will only do this if |
661 | * we didn't initialize a while ago. | 662 | * we didn't initialize a while ago. |
662 | */ | 663 | */ |
663 | if( m_boxName == 0 ){ | 664 | if( m_boxName == 0 ){ |
664 | m_boxName = new QHBox( this ); // remove this this? or use a QHBox | 665 | m_boxName = new QHBox( this ); // remove this this? or use a QHBox |
665 | m_fnLabel = new QLabel( m_boxName ); | 666 | m_fnLabel = new QLabel( m_boxName ); |
666 | m_fnLabel->setText( tr("Name:") ); | 667 | m_fnLabel->setText( tr("Name:") ); |
667 | m_edit = new QLineEdit( m_boxName ); | 668 | m_edit = new QLineEdit( m_boxName ); |
668 | m_edit->setText( m_name ); | 669 | m_edit->setText( m_name ); |
669 | //m_boxName->addWidget( m_fnLabel ); | 670 | //m_boxName->addWidget( m_fnLabel ); |
670 | m_boxName->setMargin( 5 ); | 671 | m_boxName->setMargin( 5 ); |
671 | m_boxName->setSpacing( 8 ); | 672 | m_boxName->setSpacing( 8 ); |
672 | //m_boxName->setStretchFactor(m_edit, 100 ); // 100 is stretch factor | 673 | //m_boxName->setStretchFactor(m_edit, 100 ); // 100 is stretch factor |
673 | 674 | ||
674 | m_lay->addWidget( m_boxName, 0 ); // add it to the topLevel layout | 675 | m_lay->addWidget( m_boxName, 0 ); // add it to the topLevel layout |
675 | }// else we already initialized | 676 | }// else we already initialized |
676 | // maybe show the components? | 677 | // maybe show the components? |
677 | // | 678 | // |
678 | } | 679 | } |
679 | void OFileSelector::initializeYes() | 680 | void OFileSelector::initializeYes() |
680 | { | 681 | { |
681 | /** The Save Cancel bar | 682 | /** The Save Cancel bar |
682 | * | 683 | * |
683 | */ | 684 | */ |
684 | if( m_boxOk == 0 ){ | 685 | if( m_boxOk == 0 ){ |
685 | m_boxOk = new QHBox( this ); | 686 | m_boxOk = new QHBox( this ); |
686 | m_ok = new QPushButton( tr("&Save"),m_boxOk , "save" ); | 687 | m_ok = new QPushButton( tr("&Save"),m_boxOk , "save" ); |
687 | m_cancel = new QPushButton( tr("C&ancel"), m_boxOk, "cancel" ); | 688 | m_cancel = new QPushButton( tr("C&ancel"), m_boxOk, "cancel" ); |
688 | 689 | ||
689 | //m_boxOk->addWidget( m_ok ); | 690 | //m_boxOk->addWidget( m_ok ); |
690 | //m_boxOk->addWidget( m_cancel ); | 691 | //m_boxOk->addWidget( m_cancel ); |
691 | m_boxOk->setMargin( 5 ); | 692 | m_boxOk->setMargin( 5 ); |
692 | m_boxOk->setSpacing( 10 ); | 693 | m_boxOk->setSpacing( 10 ); |
693 | m_lay->addWidget( m_boxOk, 0 ); | 694 | m_lay->addWidget( m_boxOk, 0 ); |
694 | 695 | ||
695 | connect( m_ok, SIGNAL( clicked() ), | 696 | connect( m_ok, SIGNAL( clicked() ), |
696 | this, SLOT(slotOk() ) ); | 697 | this, SLOT(slotOk() ) ); |
697 | connect( m_cancel, SIGNAL( clicked() ), | 698 | connect( m_cancel, SIGNAL( clicked() ), |
698 | this, SLOT( slotCancel() ) ); | 699 | this, SLOT( slotCancel() ) ); |
699 | } | 700 | } |
700 | } | 701 | } |
701 | /* | 702 | /* |
702 | * OK m_mimeCheck is a QComboBox we now want to fill | 703 | * OK m_mimeCheck is a QComboBox we now want to fill |
703 | * out that combobox | 704 | * out that combobox |
704 | * if automime we need to update the mimetypes | 705 | * if automime we need to update the mimetypes |
705 | */ | 706 | */ |
706 | void OFileSelector::updateMimeCheck() { | 707 | void OFileSelector::updateMimeCheck() { |
707 | m_mimeCheck->clear(); | 708 | m_mimeCheck->clear(); |
708 | if (m_autoMime ) { | 709 | if (m_autoMime ) { |
709 | //m_mimeCheck->insertItem( tr("All") ); | 710 | //m_mimeCheck->insertItem( tr("All") ); |
@@ -864,263 +865,271 @@ void OFileSelector::initPics() | |||
864 | QPixmap pm2 = Resource::loadPixmap( "lockedfolder" ); | 865 | QPixmap pm2 = Resource::loadPixmap( "lockedfolder" ); |
865 | QPainter pen(&pm2 ); | 866 | QPainter pen(&pm2 ); |
866 | pen.drawPixmap(pm2.width()-lnk.width(), pm2.height()-lnk.height(), lnk ); | 867 | pen.drawPixmap(pm2.width()-lnk.width(), pm2.height()-lnk.height(), lnk ); |
867 | pm2.setMask( pm2.createHeuristicMask( FALSE ) ); | 868 | pm2.setMask( pm2.createHeuristicMask( FALSE ) ); |
868 | m_pixmaps->insert("symlinkedlocked", pm2 ); | 869 | m_pixmaps->insert("symlinkedlocked", pm2 ); |
869 | } | 870 | } |
870 | // if a mime complies with the m_mimeCheck->currentItem | 871 | // if a mime complies with the m_mimeCheck->currentItem |
871 | bool OFileSelector::compliesMime( const QString &path, const QString &mime ) | 872 | bool OFileSelector::compliesMime( const QString &path, const QString &mime ) |
872 | { | 873 | { |
873 | if( mime == "All" ) | 874 | if( mime == "All" ) |
874 | return true; | 875 | return true; |
875 | MimeType type( path ); | 876 | MimeType type( path ); |
876 | if( type.id() == mime ) | 877 | if( type.id() == mime ) |
877 | return true; | 878 | return true; |
878 | return false; | 879 | return false; |
879 | } | 880 | } |
880 | /* check if the mimetype in mime | 881 | /* check if the mimetype in mime |
881 | * complies with the one which is current | 882 | * complies with the one which is current |
882 | */ | 883 | */ |
883 | /* | 884 | /* |
884 | * We've the mimetype of the file | 885 | * We've the mimetype of the file |
885 | * We need to get the stringlist of the current mimetype | 886 | * We need to get the stringlist of the current mimetype |
886 | * | 887 | * |
887 | * mime = image/jpeg | 888 | * mime = image/jpeg |
888 | * QStringList = 'image/*' | 889 | * QStringList = 'image/*' |
889 | * or QStringList = image/jpeg;image/png;application/x-ogg | 890 | * or QStringList = image/jpeg;image/png;application/x-ogg |
890 | * or QStringList = application/x-ogg;image/*; | 891 | * or QStringList = application/x-ogg;image/*; |
891 | * with all these mime filters it should get acceptes | 892 | * with all these mime filters it should get acceptes |
892 | * to do so we need to look if mime is contained inside | 893 | * to do so we need to look if mime is contained inside |
893 | * the stringlist | 894 | * the stringlist |
894 | * if it's contained return true | 895 | * if it's contained return true |
895 | * if not ( I'm no RegExp expert at all ) we'll look if a '/*' | 896 | * if not ( I'm no RegExp expert at all ) we'll look if a '/*' |
896 | * is contained in the mimefilter and then we will | 897 | * is contained in the mimefilter and then we will |
897 | * look if both are equal until the '/' | 898 | * look if both are equal until the '/' |
898 | */ | 899 | */ |
899 | bool OFileSelector::compliesMime( const QString& mime ) { | 900 | bool OFileSelector::compliesMime( const QString& mime ) { |
900 | qWarning("mimetype is %s", mime.latin1() ); | 901 | qWarning("mimetype is %s", mime.latin1() ); |
901 | QString currentText; | 902 | QString currentText; |
902 | if (m_shChooser ) | 903 | if (m_shChooser ) |
903 | currentText = m_mimeCheck->currentText(); | 904 | currentText = m_mimeCheck->currentText(); |
904 | 905 | ||
905 | qWarning("current text is %s", currentText.latin1() ); | 906 | qWarning("current text is %s", currentText.latin1() ); |
906 | QMap<QString, QStringList>::Iterator it; | 907 | QMap<QString, QStringList>::Iterator it; |
907 | QStringList list; | 908 | QStringList list; |
908 | if ( currentText == tr("All") ) return true; | 909 | if ( currentText == tr("All") ) return true; |
909 | else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { | 910 | else if ( currentText.isEmpty() && !m_mimetypes.isEmpty() ) { |
910 | it = m_mimetypes.begin(); | 911 | it = m_mimetypes.begin(); |
911 | list = it.data(); | 912 | list = it.data(); |
912 | }else if ( currentText.isEmpty() ) return true; | 913 | }else if ( currentText.isEmpty() ) return true; |
913 | else{ | 914 | else{ |
914 | it = m_mimetypes.find(currentText ); | 915 | it = m_mimetypes.find(currentText ); |
915 | if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; | 916 | if ( it == m_mimetypes.end() ) qWarning("not there"), list << currentText; |
916 | else qWarning("found"), list = it.data(); | 917 | else qWarning("found"), list = it.data(); |
917 | } | 918 | } |
918 | // dump it now | 919 | // dump it now |
919 | //for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { | 920 | //for ( QStringList::Iterator it = list.begin(); it != list.end(); ++it ) { |
920 | // qWarning( "%s", (*it).latin1() ); | 921 | // qWarning( "%s", (*it).latin1() ); |
921 | //} | 922 | //} |
922 | 923 | ||
923 | 924 | ||
924 | if ( list.contains(mime) ) return true; | 925 | if ( list.contains(mime) ) return true; |
925 | qWarning("list doesn't contain it "); | 926 | qWarning("list doesn't contain it "); |
926 | QStringList::Iterator it2; | 927 | QStringList::Iterator it2; |
927 | int pos; | 928 | int pos; |
928 | int pos2; | ||
929 | for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { | 929 | for ( it2 = list.begin(); it2 != list.end(); ++it2 ) { |
930 | pos = (*it2).findRev("/*"); | 930 | pos = (*it2).findRev("/*"); |
931 | if ( pos >= 0 ) { | 931 | if ( pos >= 0 ) { |
932 | if ( mime.contains( (*it2).left(pos) ) ) return true; | 932 | if ( mime.contains( (*it2).left(pos) ) ) return true; |
933 | } | 933 | } |
934 | } | 934 | } |
935 | return false; | 935 | return false; |
936 | } | 936 | } |
937 | void OFileSelector::slotFileSelected( const QString &string ) | 937 | void OFileSelector::slotFileSelected( const QString &string ) |
938 | { | 938 | { |
939 | if( m_shLne ) | 939 | if( m_shLne ) |
940 | m_edit->setText( string ); | 940 | m_edit->setText( string ); |
941 | emit fileSelected( string ); | 941 | emit fileSelected( string ); |
942 | } | 942 | } |
943 | void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) | 943 | void OFileSelector::slotFileBridgeSelected( const DocLnk &lnk ) |
944 | { | 944 | { |
945 | slotFileSelected( lnk.name() ); | 945 | slotFileSelected( lnk.name() ); |
946 | // emit fileSelected( lnk ); | 946 | // emit fileSelected( lnk ); |
947 | } | 947 | } |
948 | void OFileSelector::slotSelectionChanged() | 948 | void OFileSelector::slotSelectionChanged() |
949 | { | 949 | { |
950 | 950 | ||
951 | } | 951 | } |
952 | void OFileSelector::slotCurrentChanged(QListViewItem* item ) | 952 | void OFileSelector::slotCurrentChanged(QListViewItem* /*item*/ ) |
953 | { | 953 | { |
954 | /* | ||
954 | if( item == 0 ) | 955 | if( item == 0 ) |
955 | return; | 956 | return; |
956 | if( m_selector == Extended || m_selector == ExtendedAll ) { | 957 | if( m_selector == Extended || m_selector == ExtendedAll ) { |
957 | OFileSelectorItem *sel = (OFileSelectorItem*) item; // start to use the C++ casts ;) | 958 | OFileSelectorItem *sel = (OFileSelectorItem*) item; // start to use the C++ casts ;) |
958 | qWarning("current changed"); | 959 | qWarning("current changed"); |
959 | if(!sel->isDir() ){ | 960 | if(!sel->isDir() ){ |
960 | if( m_shLne ) | 961 | if( m_shLne ) |
961 | m_edit->setText( sel->text(1) ); | 962 | m_edit->setText( sel->text(1) ); |
962 | 963 | ||
963 | if (m_mode == Fileselector ) { | 964 | if (m_mode == Fileselector ) { |
964 | QStringList str = QStringList::split("->", sel->text(1) ); | 965 | QStringList str = QStringList::split("->", sel->text(1) ); |
965 | QString path =sel->directory() + "/" + str[0].stripWhiteSpace(); | 966 | QString path =sel->directory() + "/" + str[0].stripWhiteSpace(); |
966 | emit fileSelected(path ); | 967 | emit fileSelected(path ); |
967 | DocLnk lnk( path ); | 968 | DocLnk lnk( path ); |
968 | emit fileSelected(lnk ); | 969 | emit fileSelected(lnk ); |
969 | } | 970 | } |
970 | } | 971 | } |
971 | } | 972 | } */ |
972 | } | 973 | } |
973 | void OFileSelector::slotClicked( int button, QListViewItem *item, const QPoint &, int) | 974 | void OFileSelector::slotClicked( int /*button*/, QListViewItem */*item*/, const QPoint &, int) |
975 | |||
974 | { | 976 | { |
977 | /* | ||
975 | if ( item == 0 ) | 978 | if ( item == 0 ) |
976 | return; | 979 | return; |
977 | 980 | ||
978 | if( button != Qt::LeftButton ) | 981 | if( button != Qt::LeftButton ) |
979 | return; | 982 | return; |
980 | 983 | ||
981 | switch( m_selector ){ | 984 | switch( m_selector ){ |
982 | default: | 985 | default: |
983 | break; | 986 | break; |
984 | case Extended: // fall through | 987 | case Extended: // fall through |
985 | case ExtendedAll:{ | 988 | case ExtendedAll:{ |
986 | OFileSelectorItem *sel = (OFileSelectorItem*)item; | 989 | OFileSelectorItem *sel = (OFileSelectorItem*)item; |
987 | if(!sel->isLocked() ){ | 990 | if(!sel->isLocked() ){ |
988 | QStringList str = QStringList::split("->", sel->text(1) ); | 991 | QStringList str = QStringList::split("->", sel->text(1) ); |
989 | if( sel->isDir() ){ | 992 | if( sel->isDir() ){ |
990 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 993 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
991 | // if MODE Dir m_shLne set the Text | 994 | // if MODE Dir m_shLne set the Text |
992 | }else{ | 995 | }else{ |
993 | if( m_shLne ) | 996 | if( m_shLne ) |
994 | m_edit->setText( str[0].stripWhiteSpace() ); | 997 | m_edit->setText( str[0].stripWhiteSpace() ); |
995 | qWarning("selected here in slot clicked"); | 998 | qWarning("selected here in slot clicked"); |
996 | emit fileSelected( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 999 | emit fileSelected( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
997 | DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1000 | DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
998 | qWarning("file selected"); | 1001 | qWarning("file selected"); |
999 | emit fileSelected( lnk ); | 1002 | emit fileSelected( lnk ); |
1000 | } | 1003 | } |
1001 | } | 1004 | } |
1002 | break; | 1005 | break; |
1003 | } | 1006 | } |
1004 | } | 1007 | } */ |
1005 | } | 1008 | } |
1006 | void OFileSelector::slotRightButton(int button, QListViewItem *item, const QPoint &, int ) | 1009 | void OFileSelector::slotRightButton(int button, QListViewItem *item, const QPoint &, int ) |
1007 | { | 1010 | { |
1008 | if( item == 0 ) | 1011 | if( item == 0 ) |
1009 | return; | 1012 | return; |
1010 | 1013 | ||
1011 | if( button != Qt::RightButton ) | 1014 | if( button != Qt::RightButton ) |
1012 | return; | 1015 | return; |
1013 | slotContextMenu( item ); | 1016 | slotContextMenu( item ); |
1014 | } | 1017 | } |
1015 | void OFileSelector::slotContextMenu( QListViewItem *item) | 1018 | void OFileSelector::slotContextMenu( QListViewItem */*item*/) |
1016 | { | 1019 | { |
1017 | 1020 | ||
1018 | } | 1021 | } |
1019 | void OFileSelector::slotChangedDir() | 1022 | void OFileSelector::slotChangedDir() |
1020 | { | 1023 | { |
1024 | /* | ||
1021 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 1025 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
1022 | if(sel->isDir() ){ | 1026 | if(sel->isDir() ){ |
1023 | QStringList str = QStringList::split("->", sel->text(1) ); | 1027 | QStringList str = QStringList::split("->", sel->text(1) ); |
1024 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1028 | cd( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1025 | } | 1029 | } |
1030 | */ | ||
1026 | } | 1031 | } |
1027 | void OFileSelector::slotOpen() | 1032 | void OFileSelector::slotOpen() |
1028 | { | 1033 | { |
1034 | /* | ||
1029 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 1035 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
1030 | if(!sel->isDir() ){ | 1036 | if(!sel->isDir() ){ |
1031 | QStringList str = QStringList::split("->", sel->text(1) ); | 1037 | QStringList str = QStringList::split("->", sel->text(1) ); |
1032 | slotFileSelected( sel->directory() +"/" +str[0].stripWhiteSpace() ); | 1038 | slotFileSelected( sel->directory() +"/" +str[0].stripWhiteSpace() ); |
1033 | qWarning("slot open"); | 1039 | qWarning("slot open"); |
1034 | // DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); | 1040 | // DocLnk lnk( sel->directory() + "/" + str[0].stripWhiteSpace() ); |
1035 | //emit fileSelected( lnk ); | 1041 | //emit fileSelected( lnk ); |
1036 | } | 1042 | } |
1043 | */ | ||
1037 | } | 1044 | } |
1038 | void OFileSelector::slotRescan() | 1045 | void OFileSelector::slotRescan() |
1039 | { | 1046 | { |
1040 | 1047 | ||
1041 | } | 1048 | } |
1042 | void OFileSelector::slotRename() | 1049 | void OFileSelector::slotRename() |
1043 | { | 1050 | { |
1044 | reparse(); | 1051 | reparse(); |
1045 | } | 1052 | } |
1046 | void OFileSelector::slotDelete() | 1053 | void OFileSelector::slotDelete() |
1047 | { | 1054 | { |
1055 | /* | ||
1048 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); | 1056 | OFileSelectorItem *sel = (OFileSelectorItem*)m_View->currentItem(); |
1049 | QStringList list = QStringList::split("->", sel->text(1) ); | 1057 | QStringList list = QStringList::split("->", sel->text(1) ); |
1050 | if( sel->isDir() ){ | 1058 | if( sel->isDir() ){ |
1051 | QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry | 1059 | QString str = QString::fromLatin1("rm -rf ") + sel->directory() +"/" + list[0]; //better safe than sorry |
1052 | switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], | 1060 | switch ( QMessageBox::warning(this,tr("Delete"),tr("Do you really want to delete\n")+list[0], |
1053 | tr("Yes"),tr("No"),0,1,1) ) { | 1061 | tr("Yes"),tr("No"),0,1,1) ) { |
1054 | case 0: | 1062 | case 0: |
1055 | ::system(str.utf8().data() ); | 1063 | ::system(str.utf8().data() ); |
1056 | break; | 1064 | break; |
1057 | } | 1065 | } |
1058 | } else { | 1066 | } else { |
1059 | QFile::remove( list[0] ); | 1067 | QFile::remove( list[0] ); |
1060 | } | 1068 | } |
1061 | m_View->takeItem( sel ); | 1069 | m_View->takeItem( sel ); |
1062 | delete sel; | 1070 | delete sel; |
1071 | */ | ||
1063 | } | 1072 | } |
1064 | void OFileSelector::cdUP() | 1073 | void OFileSelector::cdUP() |
1065 | { | 1074 | { |
1066 | QDir dir( m_currentDir ); | 1075 | QDir dir( m_currentDir ); |
1067 | dir.cdUp(); | 1076 | dir.cdUp(); |
1068 | if(dir.exists() ){ | 1077 | if(dir.exists() ){ |
1069 | m_currentDir = dir.absPath(); | 1078 | m_currentDir = dir.absPath(); |
1070 | reparse(); | 1079 | reparse(); |
1071 | int count = m_location->count(); | 1080 | int count = m_location->count(); |
1072 | slotInsertLocationPath( m_currentDir, count); | 1081 | slotInsertLocationPath( m_currentDir, count); |
1073 | m_location->setCurrentItem( indexByString( m_location, m_currentDir)); | 1082 | m_location->setCurrentItem( indexByString( m_location, m_currentDir)); |
1074 | //this wont work in all instances | 1083 | //this wont work in all instances |
1075 | // FIXME | 1084 | // FIXME |
1076 | } | 1085 | } |
1077 | } | 1086 | } |
1078 | void OFileSelector::slotHome() | 1087 | void OFileSelector::slotHome() |
1079 | { | 1088 | { |
1080 | cd(QDir::homeDirPath() ); | 1089 | cd(QDir::homeDirPath() ); |
1081 | } | 1090 | } |
1082 | void OFileSelector::slotDoc() | 1091 | void OFileSelector::slotDoc() |
1083 | { | 1092 | { |
1084 | cd(QPEApplication::documentDir() ); | 1093 | cd(QPEApplication::documentDir() ); |
1085 | } | 1094 | } |
1086 | void OFileSelector::slotNavigate( ) | 1095 | void OFileSelector::slotNavigate( ) |
1087 | { | 1096 | { |
1088 | 1097 | ||
1089 | } | 1098 | } |
1090 | // fill the View with life | 1099 | // fill the View with life |
1091 | void OFileSelector::reparse() | 1100 | void OFileSelector::reparse() |
1092 | { | 1101 | { |
1093 | if( m_selector == Normal ) | 1102 | if( m_selector == Normal ) |
1094 | return; | 1103 | return; |
1095 | if( m_selector == Extended || m_selector == ExtendedAll ) | 1104 | if( m_selector == Extended || m_selector == ExtendedAll ) |
1096 | m_View->clear(); | 1105 | m_View->clear(); |
1097 | else // custom view | 1106 | else // custom view |
1098 | ; // currentView()->clear(); | 1107 | ; // currentView()->clear(); |
1099 | if( m_shChooser) | 1108 | if( m_shChooser) |
1100 | qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); | 1109 | qWarning("reparse %s", m_mimeCheck->currentText().latin1() ); |
1101 | 1110 | ||
1102 | QString currentMimeType; | 1111 | QString currentMimeType; |
1103 | // let's update the mimetype | 1112 | // let's update the mimetype |
1104 | if( m_autoMime ){ | 1113 | if( m_autoMime ){ |
1105 | m_mimetypes.clear(); | 1114 | m_mimetypes.clear(); |
1106 | // ok we can change mimetype so we need to be able to give a selection | 1115 | // ok we can change mimetype so we need to be able to give a selection |
1107 | if( m_shChooser ) { | 1116 | if( m_shChooser ) { |
1108 | currentMimeType = m_mimeCheck->currentText(); | 1117 | currentMimeType = m_mimeCheck->currentText(); |
1109 | m_mimeCheck->clear(); | 1118 | m_mimeCheck->clear(); |
1110 | 1119 | ||
1111 | // let's find possible mimetypes | 1120 | // let's find possible mimetypes |
1112 | QDir dir( m_currentDir ); | 1121 | QDir dir( m_currentDir ); |
1113 | dir.setFilter( QDir::Files | QDir::Readable ); | 1122 | dir.setFilter( QDir::Files | QDir::Readable ); |
1114 | dir.setSorting( QDir::Size ); | 1123 | dir.setSorting( QDir::Size ); |
1115 | const QFileInfoList *list = dir.entryInfoList(); | 1124 | const QFileInfoList *list = dir.entryInfoList(); |
1116 | QFileInfoListIterator it( *list ); | 1125 | QFileInfoListIterator it( *list ); |
1117 | QFileInfo *fi; | 1126 | QFileInfo *fi; |
1118 | while( (fi=it.current() ) ) { | 1127 | while( (fi=it.current() ) ) { |
1119 | if( fi->extension() == QString::fromLatin1("desktop") ){ | 1128 | if( fi->extension() == QString::fromLatin1("desktop") ){ |
1120 | ++it; | 1129 | ++it; |
1121 | continue; | 1130 | continue; |
1122 | } | 1131 | } |
1123 | MimeType type( fi->absFilePath() ); | 1132 | MimeType type( fi->absFilePath() ); |
1124 | if( !m_mimetypes.contains( type.id() ) ){ | 1133 | if( !m_mimetypes.contains( type.id() ) ){ |
1125 | //qWarning("Type %s", type.id().latin1() ); | 1134 | //qWarning("Type %s", type.id().latin1() ); |
1126 | m_mimetypes.insert( type.id(), type.id() ); | 1135 | m_mimetypes.insert( type.id(), type.id() ); |
@@ -1149,98 +1158,105 @@ void OFileSelector::reparse() | |||
1149 | if ( m_case ) | 1158 | if ( m_case ) |
1150 | sort = (QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed); | 1159 | sort = (QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed); |
1151 | else | 1160 | else |
1152 | sort = (QDir::Name | QDir::DirsFirst | QDir::Reversed); | 1161 | sort = (QDir::Name | QDir::DirsFirst | QDir::Reversed); |
1153 | dir.setSorting( sort ); | 1162 | dir.setSorting( sort ); |
1154 | 1163 | ||
1155 | int filter; | 1164 | int filter; |
1156 | if( m_selector == ExtendedAll /*|| m_selector ==CUSTOM_ALL */ ){ | 1165 | if( m_selector == ExtendedAll /*|| m_selector ==CUSTOM_ALL */ ){ |
1157 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; | 1166 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; |
1158 | }else | 1167 | }else |
1159 | filter = QDir::Files | QDir::Dirs | QDir::All; | 1168 | filter = QDir::Files | QDir::Dirs | QDir::All; |
1160 | dir.setFilter( filter ); | 1169 | dir.setFilter( filter ); |
1161 | 1170 | ||
1162 | // now go through all files | 1171 | // now go through all files |
1163 | const QFileInfoList *list = dir.entryInfoList(); | 1172 | const QFileInfoList *list = dir.entryInfoList(); |
1164 | QFileInfoListIterator it( *list ); | 1173 | QFileInfoListIterator it( *list ); |
1165 | QFileInfo *fi; | 1174 | QFileInfo *fi; |
1166 | while( (fi=it.current() ) ){ | 1175 | while( (fi=it.current() ) ){ |
1167 | //qWarning("True and only" ); | 1176 | //qWarning("True and only" ); |
1168 | if( fi->fileName() == QString::fromLatin1("..") || fi->fileName() == QString::fromLatin1(".") ){ | 1177 | if( fi->fileName() == QString::fromLatin1("..") || fi->fileName() == QString::fromLatin1(".") ){ |
1169 | //qWarning(".. or ." ); | 1178 | //qWarning(".. or ." ); |
1170 | ++it; | 1179 | ++it; |
1171 | continue; | 1180 | continue; |
1172 | } | 1181 | } |
1173 | if( fi->isSymLink() ){ | 1182 | if( fi->isSymLink() ){ |
1174 | QString file = fi->dirPath( true ) + "/" + fi->readLink(); | 1183 | QString file = fi->dirPath( true ) + "/" + fi->readLink(); |
1175 | for( int i = 0; i<=4; i++) { // 5 tries to prevent dos | 1184 | for( int i = 0; i<=4; i++) { // 5 tries to prevent dos |
1176 | QFileInfo info( file ); | 1185 | QFileInfo info( file ); |
1177 | if( !info.exists() ){ | 1186 | if( !info.exists() ){ |
1178 | addSymlink( currentMimeType, fi, TRUE ); | 1187 | addSymlink( currentMimeType, fi, TRUE ); |
1179 | break; | 1188 | break; |
1180 | }else if( info.isDir() ){ | 1189 | }else if( info.isDir() ){ |
1181 | addDir( currentMimeType, fi, TRUE ); | 1190 | addDir( currentMimeType, fi, TRUE ); |
1182 | break; | 1191 | break; |
1183 | }else if( info.isFile() ){ | 1192 | }else if( info.isFile() ){ |
1184 | addFile( currentMimeType, fi, TRUE ); | 1193 | addFile( currentMimeType, fi, TRUE ); |
1185 | break; | 1194 | break; |
1186 | }else if( info.isSymLink() ){ | 1195 | }else if( info.isSymLink() ){ |
1187 | file = info.dirPath(true ) + "/" + info.readLink() ; | 1196 | file = info.dirPath(true ) + "/" + info.readLink() ; |
1188 | break; | 1197 | break; |
1189 | }else if( i == 4){ | 1198 | }else if( i == 4){ |
1190 | addSymlink( currentMimeType, fi ); | 1199 | addSymlink( currentMimeType, fi ); |
1191 | } | 1200 | } |
1192 | } // off for loop | 1201 | } // off for loop |
1193 | }else if( fi->isDir() ){ | 1202 | }else if( fi->isDir() ){ |
1194 | addDir( currentMimeType, fi ); | 1203 | addDir( currentMimeType, fi ); |
1195 | }else if( fi->isFile() ){ | 1204 | }else if( fi->isFile() ){ |
1196 | addFile( currentMimeType, fi ); | 1205 | addFile( currentMimeType, fi ); |
1197 | } | 1206 | } |
1198 | //qWarning( "%s", fi->fileName().latin1() ); | 1207 | //qWarning( "%s", fi->fileName().latin1() ); |
1199 | ++it; | 1208 | ++it; |
1200 | } // of while loop | 1209 | } // of while loop |
1201 | m_View->sort(); | 1210 | m_View->sort(); |
1202 | if( m_shTool ){ | 1211 | if( m_shTool ){ |
1203 | m_location->insertItem( m_currentDir ); | 1212 | m_location->insertItem( m_currentDir ); |
1204 | 1213 | ||
1205 | } | 1214 | } |
1206 | // reenable painting and updates | 1215 | // reenable painting and updates |
1207 | } | 1216 | } |
1208 | 1217 | ||
1209 | 1218 | ||
1210 | OFileView* OFileSelector::currentView() { | 1219 | OFileView* OFileSelector::currentView() { |
1211 | return 0l; | 1220 | return 0l; |
1212 | } | 1221 | } |
1222 | OFileView* OFileSelector::currentView() const{ | ||
1223 | return 0l; | ||
1224 | } | ||
1213 | int OFileSelector::filter() { | 1225 | int OFileSelector::filter() { |
1214 | int filter; | 1226 | int filter; |
1215 | if ( m_selector == ExtendedAll ) | 1227 | if ( m_selector == ExtendedAll ) |
1216 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; | 1228 | filter = QDir::Files | QDir::Dirs | QDir::Hidden | QDir::All; |
1217 | else | 1229 | else |
1218 | filter = QDir::Files | QDir::Dirs | QDir::All ; | 1230 | filter = QDir::Files | QDir::Dirs | QDir::All ; |
1219 | 1231 | ||
1220 | return filter; | 1232 | return filter; |
1221 | } | 1233 | } |
1222 | int OFileSelector::sorting() { | 1234 | int OFileSelector::sorting() { |
1223 | int sort; | 1235 | int sort; |
1224 | 1236 | ||
1225 | if (m_case ) | 1237 | if (m_case ) |
1226 | sort = ( QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed ); | 1238 | sort = ( QDir::IgnoreCase | QDir::Name | QDir::DirsFirst | QDir::Reversed ); |
1227 | else | 1239 | else |
1228 | sort = ( QDir::Name | QDir::DirsFirst | QDir::Reversed ); | 1240 | sort = ( QDir::Name | QDir::DirsFirst | QDir::Reversed ); |
1229 | 1241 | ||
1230 | return sort; | 1242 | return sort; |
1231 | } | 1243 | } |
1232 | void OFileSelector::internFileSelected( const QString& s) { | 1244 | void OFileSelector::internFileSelected( const QString& s) { |
1233 | emit fileSelected( s ); | 1245 | emit fileSelected( s ); |
1234 | } | 1246 | } |
1235 | void OFileSelector::internFileSelected( const DocLnk& d ) { | 1247 | void OFileSelector::internFileSelected( const DocLnk& d ) { |
1236 | emit fileSelected( d ); | 1248 | emit fileSelected( d ); |
1237 | } | 1249 | } |
1238 | void OFileSelector::internContextMenu() { | 1250 | void OFileSelector::internContextMenu() { |
1239 | emit contextMenu(); | 1251 | emit contextMenu(); |
1240 | } | 1252 | } |
1241 | void OFileSelector::internChangedDir( const QString& s) { | 1253 | void OFileSelector::internChangedDir( const QString& s) { |
1242 | emit dirSelected( s ); | 1254 | emit dirSelected( s ); |
1243 | } | 1255 | } |
1244 | void OFileSelector::internChangedDir( const QDir& s) { | 1256 | void OFileSelector::internChangedDir( const QDir& s) { |
1245 | emit dirSelected( s ); | 1257 | emit dirSelected( s ); |
1246 | } | 1258 | } |
1259 | QPixmap OFileSelector::pixmap( const QString& s ) { | ||
1260 | |||
1261 | return (*m_pixmaps)[s]; | ||
1262 | } | ||
diff --git a/libopie/ofileselector/ofileselector.h b/libopie/ofileselector/ofileselector.h index 937569d..12af732 100644 --- a/libopie/ofileselector/ofileselector.h +++ b/libopie/ofileselector/ofileselector.h | |||
@@ -275,130 +275,132 @@ class OFileSelector : public QWidget { | |||
275 | int selector()const { return m_selector; }; | 275 | int selector()const { return m_selector; }; |
276 | 276 | ||
277 | /** | 277 | /** |
278 | * set the Selector | 278 | * set the Selector |
279 | */ | 279 | */ |
280 | void setSelector( int ); | 280 | void setSelector( int ); |
281 | 281 | ||
282 | /** | 282 | /** |
283 | * wether or not to show popups | 283 | * wether or not to show popups |
284 | */ | 284 | */ |
285 | bool showPopup()const { return m_showPopup; }; | 285 | bool showPopup()const { return m_showPopup; }; |
286 | 286 | ||
287 | /** | 287 | /** |
288 | * set show popups | 288 | * set show popups |
289 | */ | 289 | */ |
290 | void setShowPopup( bool pop ) { m_showPopup = pop; } | 290 | void setShowPopup( bool pop ) { m_showPopup = pop; } |
291 | 291 | ||
292 | /** | 292 | /** |
293 | * set the popup factory | 293 | * set the popup factory |
294 | */ | 294 | */ |
295 | void setPopupFactory( OPopupMenuFactory * ); | 295 | void setPopupFactory( OPopupMenuFactory * ); |
296 | 296 | ||
297 | /** | 297 | /** |
298 | * reparse the current directory and updates | 298 | * reparse the current directory and updates |
299 | * the views + mimetypes | 299 | * the views + mimetypes |
300 | */ | 300 | */ |
301 | void reparse(); // re reads the dir | 301 | void reparse(); // re reads the dir |
302 | 302 | ||
303 | /** | 303 | /** |
304 | * return the selected name | 304 | * return the selected name |
305 | */ | 305 | */ |
306 | QString selectedName( )const; | 306 | QString selectedName( )const; |
307 | 307 | ||
308 | /** | 308 | /** |
309 | * for multiple selections return multiple | 309 | * for multiple selections return multiple |
310 | * filenames | 310 | * filenames |
311 | */ | 311 | */ |
312 | QStringList selectedNames()const; | 312 | QStringList selectedNames()const; |
313 | 313 | ||
314 | /** | 314 | /** |
315 | * return the complete to the file | 315 | * return the complete to the file |
316 | */ | 316 | */ |
317 | QString selectedPath() const; | 317 | QString selectedPath() const; |
318 | 318 | ||
319 | /** | 319 | /** |
320 | * return the completed paths | 320 | * return the completed paths |
321 | */ | 321 | */ |
322 | QStringList selectedPaths() const; | 322 | QStringList selectedPaths() const; |
323 | 323 | ||
324 | /** | 324 | /** |
325 | * the current directory | 325 | * the current directory |
326 | */ | 326 | */ |
327 | QString directory()const; | 327 | QString directory()const; |
328 | 328 | ||
329 | /** | 329 | /** |
330 | * fileCount | 330 | * fileCount |
331 | */ | 331 | */ |
332 | int fileCount(); | 332 | int fileCount(); |
333 | 333 | ||
334 | DocLnk selectedDocument()const; | 334 | DocLnk selectedDocument()const; |
335 | 335 | ||
336 | QValueList<DocLnk> selectedDocuments()const; | 336 | QValueList<DocLnk> selectedDocuments()const; |
337 | 337 | ||
338 | OFileView* currentView(); | 338 | OFileView* currentView(); |
339 | OFileView* currentView()const; | ||
339 | int filter(); | 340 | int filter(); |
340 | int sorting(); | 341 | int sorting(); |
342 | QPixmap pixmap( const QString& ); | ||
341 | 343 | ||
342 | signals: | 344 | signals: |
343 | void fileSelected( const DocLnk & ); | 345 | void fileSelected( const DocLnk & ); |
344 | void fileSelected( const QString & ); | 346 | void fileSelected( const QString & ); |
345 | void dirSelected(const QString &dir ); | 347 | void dirSelected(const QString &dir ); |
346 | void dirSelected( const QDir& ); | 348 | void dirSelected( const QDir& ); |
347 | void closeMe(); | 349 | void closeMe(); |
348 | void ok(); | 350 | void ok(); |
349 | void cancel(); | 351 | void cancel(); |
350 | void contextMenu(); | 352 | void contextMenu(); |
351 | 353 | ||
352 | private slots: | 354 | private slots: |
353 | void slotOk(); | 355 | void slotOk(); |
354 | void slotCancel(); | 356 | void slotCancel(); |
355 | void slotViewCheck(const QString & ); | 357 | void slotViewCheck(const QString & ); |
356 | void slotMimeCheck(const QString & ); | 358 | void slotMimeCheck(const QString & ); |
357 | void slotLocationActivated(const QString & ); | 359 | void slotLocationActivated(const QString & ); |
358 | void slotInsertLocationPath(const QString &, int); | 360 | void slotInsertLocationPath(const QString &, int); |
359 | void locationComboChanged(); | 361 | void locationComboChanged(); |
360 | 362 | ||
361 | private: | 363 | private: |
362 | void init(); | 364 | void init(); |
363 | void updateMimes(); | 365 | void updateMimes(); |
364 | 366 | ||
365 | 367 | ||
366 | private: | 368 | private: |
367 | 369 | ||
368 | FileSelector* m_select; | 370 | FileSelector* m_select; |
369 | int m_mode, m_selector; | 371 | int m_mode, m_selector; |
370 | QComboBox *m_location, *m_mimeCheck, *m_viewCheck; | 372 | QComboBox *m_location, *m_mimeCheck, *m_viewCheck; |
371 | QPushButton *m_homeButton, *m_docButton, *m_hideButton, *m_ok, *m_cancel; | 373 | QPushButton *m_homeButton, *m_docButton, *m_hideButton, *m_ok, *m_cancel; |
372 | QPushButton *m_reread, *m_up, *m_new, *m_close; | 374 | QPushButton *m_reread, *m_up, *m_new, *m_close; |
373 | QListView *m_View; | 375 | QListView *m_View; |
374 | QCheckBox *m_checkPerm; | 376 | QCheckBox *m_checkPerm; |
375 | QWidget *m_pseudo; | 377 | QWidget *m_pseudo; |
376 | QVBoxLayout *m_pseudoLayout; | 378 | QVBoxLayout *m_pseudoLayout; |
377 | 379 | ||
378 | QString m_currentDir; | 380 | QString m_currentDir; |
379 | QString m_name; | 381 | QString m_name; |
380 | // QStringList m_mimetypes; | 382 | // QStringList m_mimetypes; |
381 | QMap<QString, QStringList> m_mimetypes; | 383 | QMap<QString, QStringList> m_mimetypes; |
382 | 384 | ||
383 | 385 | ||
384 | QWidgetStack *m_stack; | 386 | QWidgetStack *m_stack; |
385 | QVBoxLayout *m_lay; | 387 | QVBoxLayout *m_lay; |
386 | QGridLayout *m_Oselector; | 388 | QGridLayout *m_Oselector; |
387 | 389 | ||
388 | QHBox *m_boxToolbar; | 390 | QHBox *m_boxToolbar; |
389 | QHBox *m_boxOk; // (no layout anymore) wait | 391 | QHBox *m_boxOk; // (no layout anymore) wait |
390 | QHBox *m_boxName; // (no Layout anymore) wait | 392 | QHBox *m_boxName; // (no Layout anymore) wait |
391 | QHBox *m_boxView; | 393 | QHBox *m_boxView; |
392 | 394 | ||
393 | QPopupMenu *m_custom; | 395 | QPopupMenu *m_custom; |
394 | 396 | ||
395 | QLineEdit *m_edit; | 397 | QLineEdit *m_edit; |
396 | QLabel *m_fnLabel; | 398 | QLabel *m_fnLabel; |
397 | 399 | ||
398 | bool m_shClose : 1; | 400 | bool m_shClose : 1; |
399 | bool m_shNew : 1; | 401 | bool m_shNew : 1; |
400 | bool m_shTool : 1; | 402 | bool m_shTool : 1; |
401 | bool m_shPerm : 1; | 403 | bool m_shPerm : 1; |
402 | bool m_shLne : 1; | 404 | bool m_shLne : 1; |
403 | bool m_shChooser : 1; | 405 | bool m_shChooser : 1; |
404 | bool m_shYesNo : 1; | 406 | bool m_shYesNo : 1; |
diff --git a/libopie/ofileselector/ofileview.cpp b/libopie/ofileselector/ofileview.cpp index 71843c1..9bb40c9 100644 --- a/libopie/ofileselector/ofileview.cpp +++ b/libopie/ofileselector/ofileview.cpp | |||
@@ -1,28 +1,31 @@ | |||
1 | #include <qpe/applnk.h> | 1 | #include <qpe/applnk.h> |
2 | 2 | ||
3 | #include "ofileselector.h" | 3 | #include "ofileselector.h" |
4 | 4 | ||
5 | #include "ofileview.h" | 5 | #include "ofileview.h" |
6 | 6 | ||
7 | 7 | ||
8 | OFileView::OFileView( OFileSelector* sel) | 8 | OFileView::OFileView( OFileSelector* sel) |
9 | : m_sel( sel ) | 9 | : m_sel( sel ) |
10 | { | 10 | { |
11 | } | 11 | } |
12 | OFileView::~OFileView() { | 12 | OFileView::~OFileView() { |
13 | } | 13 | } |
14 | void OFileView::fileSelected( const QString& s ) { | 14 | void OFileView::fileSelected( const QString& s ) { |
15 | m_sel->internFileSelected( s ); | 15 | m_sel->internFileSelected( s ); |
16 | } | 16 | } |
17 | void OFileView::fileSelected( const DocLnk& s) { | 17 | void OFileView::fileSelected( const DocLnk& s) { |
18 | m_sel->internFileSelected( s ); | 18 | m_sel->internFileSelected( s ); |
19 | } | 19 | } |
20 | void OFileView::contextMenu() { | 20 | void OFileView::contextMenu() { |
21 | m_sel->internContextMenu(); | 21 | m_sel->internContextMenu(); |
22 | } | 22 | } |
23 | void OFileView::changedDir( const QString& s) { | 23 | void OFileView::changedDir( const QString& s) { |
24 | m_sel->internChangedDir( s ); | 24 | m_sel->internChangedDir( s ); |
25 | } | 25 | } |
26 | void OFileView::changedDir( const QDir& d ) { | 26 | void OFileView::changedDir( const QDir& d ) { |
27 | m_sel->internChangedDir( d ); | 27 | m_sel->internChangedDir( d ); |
28 | } | 28 | } |
29 | OFileSelector* OFileView::selector() const { | ||
30 | return m_sel; | ||
31 | } | ||
diff --git a/libopie/ofileselector/ofileview.h b/libopie/ofileselector/ofileview.h index 997266a..1b397f5 100644 --- a/libopie/ofileselector/ofileview.h +++ b/libopie/ofileselector/ofileview.h | |||
@@ -29,81 +29,81 @@ | |||
29 | #ifndef ofileview_h | 29 | #ifndef ofileview_h |
30 | #define ofileview_h | 30 | #define ofileview_h |
31 | 31 | ||
32 | #include <qobject.h> | 32 | #include <qobject.h> |
33 | #include <qwidget.h> | 33 | #include <qwidget.h> |
34 | #include <qpopupmenu.h> | 34 | #include <qpopupmenu.h> |
35 | 35 | ||
36 | class QFileInfo; | 36 | class QFileInfo; |
37 | class QDir; | 37 | class QDir; |
38 | class DocLnk; | 38 | class DocLnk; |
39 | 39 | ||
40 | /** | 40 | /** |
41 | * A OFileView is a specialised View for the | 41 | * A OFileView is a specialised View for the |
42 | * OFileSelector | 42 | * OFileSelector |
43 | * With a View you can chage the user visible | 43 | * With a View you can chage the user visible |
44 | * representation of a OFileLister | 44 | * representation of a OFileLister |
45 | * OFileView is just a basic interface which helps you to | 45 | * OFileView is just a basic interface which helps you to |
46 | * write new views | 46 | * write new views |
47 | */ | 47 | */ |
48 | class OFileSelector; | 48 | class OFileSelector; |
49 | class OFileView { | 49 | class OFileView { |
50 | public: | 50 | public: |
51 | OFileView( OFileSelector* ); | 51 | OFileView( OFileSelector* ); |
52 | OFileView(); | 52 | OFileView(); |
53 | virtual ~OFileView(); | 53 | virtual ~OFileView(); |
54 | 54 | ||
55 | virtual void clear() = 0; | 55 | virtual void clear() = 0; |
56 | virtual void addFile(const QString &mine, | 56 | virtual void addFile(const QString &mine, |
57 | QFileInfo *info, | 57 | QFileInfo *info, |
58 | bool isSymlink = FALSE ) = 0; | 58 | bool isSymlink = FALSE ) = 0; |
59 | virtual void addFile(const QString& mine, const QString& dir, | 59 | virtual void addFile(const QString& mine, const QString& dir, |
60 | const QString& file, bool = FALSE ) = 0; | 60 | const QString& file, bool = FALSE ) = 0; |
61 | 61 | ||
62 | virtual void addDir (const QString &mine, | 62 | virtual void addDir (const QString &mine, |
63 | QFileInfo *info, | 63 | QFileInfo *info, |
64 | bool isSymlink = FALSE ) = 0; | 64 | bool isSymlink = FALSE ) = 0; |
65 | virtual void addDir (const QString& mine, const QString& dir, | 65 | virtual void addDir (const QString& mine, const QString& dir, |
66 | const QString& file, bool = FALSE) = 0; | 66 | const QString& file, bool = FALSE) = 0; |
67 | 67 | ||
68 | virtual void addSymlink(const QString &mime, | 68 | virtual void addSymlink(const QString &mime, |
69 | QFileInfo *info, | 69 | QFileInfo *info, |
70 | bool isSymlink = FALSE ) = 0; | 70 | bool isSymlink = FALSE ) = 0; |
71 | virtual void addSymlink(const QString& mine, | 71 | virtual void addSymlink(const QString& mine, |
72 | const QString& path, | 72 | const QString& path, |
73 | const QString& file, | 73 | const QString& file, |
74 | bool isSymlink = FALSE ) = 0; | 74 | bool isSymlink = FALSE ) = 0; |
75 | 75 | ||
76 | virtual void cd(const QString &path ) = 0; | 76 | virtual void cd(const QString &path ) = 0; |
77 | virtual QWidget* widget() = 0; | 77 | virtual QWidget* widget() = 0; |
78 | 78 | ||
79 | virtual QString selectedName()const = 0; | 79 | virtual QString selectedName()const = 0; |
80 | virtual QStringList selectedNames()const = 0; | 80 | virtual QStringList selectedNames()const = 0; |
81 | virtual QString selectedPath()const = 0; | 81 | virtual QString selectedPath()const = 0; |
82 | virtual QStringList selectedPaths()const = 0; | 82 | virtual QStringList selectedPaths()const = 0; |
83 | virtual int fileCount() = 0; | 83 | virtual int fileCount() = 0; |
84 | 84 | ||
85 | /*signals:*/ | 85 | /*signals:*/ |
86 | protected: | 86 | protected: |
87 | 87 | ||
88 | void fileSelected(const QString &); | 88 | void fileSelected(const QString &); |
89 | void fileSelected(const DocLnk & ); | 89 | void fileSelected(const DocLnk & ); |
90 | void contextMenu(); | 90 | void contextMenu(); |
91 | void changedDir(const QString &); | 91 | void changedDir(const QString &); |
92 | void changedDir(const QDir & ); | 92 | void changedDir(const QDir & ); |
93 | OFileSelector* selector(); | 93 | OFileSelector* selector()const; |
94 | 94 | ||
95 | private: | 95 | private: |
96 | OFileSelector* m_sel; | 96 | OFileSelector* m_sel; |
97 | }; | 97 | }; |
98 | 98 | ||
99 | class OFileViewFactory { | 99 | class OFileViewFactory { |
100 | public: | 100 | public: |
101 | OFileViewFactory() {} ; | 101 | OFileViewFactory() {} ; |
102 | virtual ~OFileViewFactory() = 0; | 102 | virtual ~OFileViewFactory() = 0; |
103 | 103 | ||
104 | OFileView* newView(QWidget *parent, const char *name ); | 104 | OFileView* newView(QWidget *parent, const char *name ); |
105 | QString name()const; | 105 | QString name()const; |
106 | }; | 106 | }; |
107 | 107 | ||
108 | 108 | ||
109 | #endif | 109 | #endif |