summaryrefslogtreecommitdiff
authorllornkcor <llornkcor>2002-05-06 19:00:18 (UTC)
committer llornkcor <llornkcor>2002-05-06 19:00:18 (UTC)
commitd1dd3ae2eb11a9c6e83eaad817a6f84a53d68691 (patch) (unidiff)
tree190c870ef6cae2ca27c71e75d84e828174c8f000
parent26c522550dc1736a463efbe8c1cdc19f83a85f5d (diff)
downloadopie-d1dd3ae2eb11a9c6e83eaad817a6f84a53d68691.zip
opie-d1dd3ae2eb11a9c6e83eaad817a6f84a53d68691.tar.gz
opie-d1dd3ae2eb11a9c6e83eaad817a6f84a53d68691.tar.bz2
added translation stuff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/settings/tabmanager/tabmanager.cpp27
1 files changed, 17 insertions, 10 deletions
diff --git a/noncore/settings/tabmanager/tabmanager.cpp b/noncore/settings/tabmanager/tabmanager.cpp
index db65d26..af76251 100644
--- a/noncore/settings/tabmanager/tabmanager.cpp
+++ b/noncore/settings/tabmanager/tabmanager.cpp
@@ -38,60 +38,62 @@
38#include <qtextstream.h> 38#include <qtextstream.h>
39#include <qlistview.h> 39#include <qlistview.h>
40#include <qheader.h> 40#include <qheader.h>
41#include <qlineedit.h> 41#include <qlineedit.h>
42#include <qlabel.h> 42#include <qlabel.h>
43#include <qmessagebox.h> 43#include <qmessagebox.h>
44#include <stdlib.h> 44#include <stdlib.h>
45#include <qpe/qcopenvelope_qws.h> 45#include <qpe/qcopenvelope_qws.h>
46 46
47#define HOME_APP_DIR QPEApplication::qpeDir()+"/apps" // <-- made this a little more flexible 47#define HOME_APP_DIR QPEApplication::qpeDir()+"/apps" // <-- made this a little more flexible
48#define HOME_APP_INSTALL_DIR "/usr/lib/ipkg/info" 48#define HOME_APP_INSTALL_DIR "/usr/lib/ipkg/info"
49#define NEW_FOLDER "EmptyTab" 49#define NEW_FOLDER "EmptyTab"
50#define NEW_APPLICATION "NewApp" 50#define NEW_APPLICATION "NewApp"
51#define APPLICATION_EXTENSION ".desktop" 51#define APPLICATION_EXTENSION ".desktop"
52#define APPLICATION_EXTENSION_LENGTH 8 52#define APPLICATION_EXTENSION_LENGTH 8
53 53
54/** 54/**
55 * Constructor. Sets up signals. Performs initial scan of applications 55 * Constructor. Sets up signals. Performs initial scan of applications
56 * and tabs 56 * and tabs
57 */ 57 */
58TabManager::TabManager( QWidget* parent, const char* name):TabManagerBase(parent, name), changed(false){ 58TabManager::TabManager( QWidget* parent, const char* name):TabManagerBase(parent, name), changed(false){
59 rescanFolder(HOME_APP_DIR); 59 rescanFolder(HOME_APP_DIR);
60 60
61 // Connect the signals and slots 61 // Connect the signals and slots
62 connect(tabList, SIGNAL(doubleClicked(QListViewItem *)), this, SLOT(editItem(QListViewItem*))); 62 connect(tabList, SIGNAL(doubleClicked(QListViewItem *)),
63 this, SLOT(editItem(QListViewItem*)));
63 (tabList->header())->hide(); 64 (tabList->header())->hide();
64 connect(tabList, SIGNAL(moveItem(QListViewItem *, QListViewItem *)), this, SLOT(moveApplication(QListViewItem *, QListViewItem *))); 65 connect(tabList, SIGNAL(moveItem(QListViewItem *, QListViewItem *)),
66 this, SLOT(moveApplication(QListViewItem *, QListViewItem *)));
65} 67}
66 68
67/** 69/**
68 * If anything in the tab's have been changed then update the system or alert 70 * If anything in the tab's have been changed then update the system or alert
69 * the user. 71 * the user.
70 */ 72 */
71TabManager::~TabManager(){ 73TabManager::~TabManager(){
72 if(changed){ 74 if(changed){
73 //QMessageBox::critical(this, "Message", "Please restart Qtopia to see all new changes.",QString("Ok") ); 75 //QMessageBox::critical(this, tr("Message"), tr("Please restart Qtopia to see all new changes."),tr("Ok") );
74 //filename = fn; 76 //filename = fn;
75 QCopEnvelope e("QPE/System", "linkChanged(QString)"); 77 QCopEnvelope e("QPE/System", "linkChanged(QString)");
76 //e << description << filename << mimetype; 78 //e << description << filename << mimetype;
77 QString link; //we'll just send an empty string 79 QString link; //we'll just send an empty string
78 e << link; 80 e << link;
79 } 81 }
80} 82}
81 83
82/** 84/**
83 * Scans root directory for any tabs or applications. Will recursivly go down, 85 * Scans root directory for any tabs or applications. Will recursivly go down,
84 * but will not follow symlinks. 86 * but will not follow symlinks.
85 * @param directory - the directory to look in. 87 * @param directory - the directory to look in.
86 * @param parent - the parent to place any new tabs or apps into. If parent is 88 * @param parent - the parent to place any new tabs or apps into. If parent is
87 * NULL then the item is a tab and should be placed as a child of the window. 89 * NULL then the item is a tab and should be placed as a child of the window.
88 */ 90 */
89void TabManager::rescanFolder(QString directory, QListViewItem* parent){ 91void TabManager::rescanFolder(QString directory, QListViewItem* parent){
90 //qDebug(QString("rescanFolder: ") + directory.latin1()); 92 //qDebug(QString("rescanFolder: ") + directory.latin1());
91 93
92 QDir d; 94 QDir d;
93 d.setPath(directory); 95 d.setPath(directory);
94 // Show hidden files for .directories 96 // Show hidden files for .directories
95 d.setFilter( QDir::Files | QDir::Hidden | QDir::Dirs); 97 d.setFilter( QDir::Files | QDir::Hidden | QDir::Dirs);
96 98
97 const QFileInfoList *list = d.entryInfoList(); 99 const QFileInfoList *list = d.entryInfoList();
@@ -182,146 +184,150 @@ void TabManager::newApplication(){
182 184
183 system((QString("echo Type=") + folderName + " | cat >> " + homeLocation).latin1()); 185 system((QString("echo Type=") + folderName + " | cat >> " + homeLocation).latin1());
184 186
185 // Insert into the tree 187 // Insert into the tree
186 QListViewItem *newItem = new QListViewItem(item, NEW_APPLICATION); 188 QListViewItem *newItem = new QListViewItem(item, NEW_APPLICATION);
187 itemList.insert(newItem, homeLocation ); 189 itemList.insert(newItem, homeLocation );
188 190
189 // We have changed something. 191 // We have changed something.
190 changed = true; 192 changed = true;
191} 193}
192 194
193/** 195/**
194 * Remove the item. 196 * Remove the item.
195 * Check if we can 197 * Check if we can
196 * Prompt user 198 * Prompt user
197 * Delete physical file (Dir, remove .dir, then dir. File, remove file) 199 * Delete physical file (Dir, remove .dir, then dir. File, remove file)
198 * Remove from installer if need too. 200 * Remove from installer if need too.
199 */ 201 */
200void TabManager::removeItem(){ 202void TabManager::removeItem(){
201 // Make sure we can delete 203 // Make sure we can delete
202 QListViewItem *item = tabList->currentItem(); 204 QListViewItem *item = tabList->currentItem();
203 if(!item) 205 if(!item)
204 return; 206 return;
205 if(item->childCount() > 0){ 207 if(item->childCount() > 0){
206 QMessageBox::critical(this, "Message", "Can't remove with applications\nstill in the group.",QString("Ok") ); 208 QMessageBox::critical(this, tr("Message"), tr("Can't remove with applications\nstill in the group."),
209 tr("Ok") );
207 return; 210 return;
208 } 211 }
209 212
210 // Prompt. 213 // Prompt.
211 int answer = QMessageBox::warning(this, "Message", "Are you sure you want to delete?","Yes", "Cancel", 0, 1 ); 214 int answer = QMessageBox::warning(this, tr("Message"), tr("Are you sure you want to delete?"),
215 tr("Yes"), tr("Cancel"), 0, 1 );
212 if (answer) 216 if (answer)
213 return; 217 return;
214 218
215 bool removeSuccessfull = true; 219 bool removeSuccessfull = true;
216 QString location = itemList[item]; 220 QString location = itemList[item];
217 // Remove file (.directory in a Directory case) 221 // Remove file (.directory in a Directory case)
218 if(!QFile::remove(location)) 222 if(!QFile::remove(location))
219 removeSuccessfull = false; 223 removeSuccessfull = false;
220 224
221 // Remove directory 225 // Remove directory
222 if(item->parent() == NULL){ 226 if(item->parent() == NULL){
223 // Remove .directory file string 227 // Remove .directory file string
224 location = location.mid(0,location.length()-10); 228 location = location.mid(0,location.length()-10);
225 QDir dir; 229 QDir dir;
226 if(!dir.rmdir(location)) 230 if(!dir.rmdir(location))
227 removeSuccessfull = false; 231 removeSuccessfull = false;
228 } 232 }
229 233
230 // If removing failed. 234 // If removing failed.
231 if(!removeSuccessfull){ 235 if(!removeSuccessfull){
232 qDebug((QString("removeItem: ") + location).latin1()); 236 qDebug((QString("removeItem: ") + location).latin1());
233 QMessageBox::critical(this, "Message", "Can't remove.",QString("Ok") ); 237 QMessageBox::critical(this, tr("Message"), tr("Can't remove."),
238 tr("Ok") );
234 return; 239 return;
235 } 240 }
236 241
237 // Remove from the installer so it wont fail. 242 // Remove from the installer so it wont fail.
238 // Don't need to do this sense the current install uses rm -f so no error 243 // Don't need to do this sense the current install uses rm -f so no error
239 244
240 // Remove from the gui list. 245 // Remove from the gui list.
241 itemList.remove(item); 246 itemList.remove(item);
242 if(item->parent()) 247 if(item->parent())
243 item->parent()->takeItem(item); 248 item->parent()->takeItem(item);
244 delete item; 249 delete item;
245 250
246 // We have changed something. 251 // We have changed something.
247 changed = true; 252 changed = true;
248} 253}
249 254
250/** 255/**
251 * Helper function. Edits the current item. 256 * Helper function. Edits the current item.
252 * calls editItem with the currently selected item. 257 * calls editItem with the currently selected item.
253 */ 258 */
254void TabManager::editCurrentItem(){ 259void TabManager::editCurrentItem(){
255 editItem(tabList->currentItem()); 260 editItem(tabList->currentItem());
256} 261}
257 262
258/** 263/**
259 * Edit the item that is passed in. 264 * Edit the item that is passed in.
260 * Show application dialog and if anything changed 265 * Show application dialog and if anything changed
261 * @param item the item to edit. 266 * @param item the item to edit.
262 */ 267 */
263void TabManager::editItem( QListViewItem * item){ 268void TabManager::editItem( QListViewItem * item){
264 if(!item) 269 if(!item)
265 return; 270 return;
266 271
267 TabAppLnk app(itemList[item]); 272 TabAppLnk app(itemList[item]);
268 if(!app.isValid()){ 273 if(!app.isValid()){
269 qDebug(QString("editItem: Not a valid applnk file: ") + itemList[item].latin1()); 274 qDebug(QString("editItem: Not a valid applnk file: ") + itemList[item].latin1());
270 return; 275 return;
271 } 276 }
272 277
273 AppEdit application(this, "Application edit", true); 278 AppEdit application(this, tr("Application edit"), true);
274 application.nameLineEdit->setText(app.name()); 279 application.nameLineEdit->setText(app.name());
275 application.iconLineEdit->setText(app.pixmapString()); 280 application.iconLineEdit->setText(app.pixmapString());
276 application.execLineEdit->setText(app.exec()); 281 application.execLineEdit->setText(app.exec());
277 application.commentLineEdit->setText(app.comment()); 282 application.commentLineEdit->setText(app.comment());
278 283
279 if(item->parent() == NULL){ 284 if(item->parent() == NULL){
280 application.execLineEdit->setEnabled(false); 285 application.execLineEdit->setEnabled(false);
281 application.TextLabel3->setEnabled(false); 286 application.TextLabel3->setEnabled(false);
282 application.setCaption("Tab"); 287 application.setCaption(tr("Tab"));
283 } 288 }
284 289
285 // Only do somthing if they hit OK 290 // Only do somthing if they hit OK
286 if(application.exec() == 0) 291 if(application.exec() == 0)
287 return; 292 return;
288 293
289 // If nothing has changed exit (hmmm why did they hit ok?) 294 // If nothing has changed exit (hmmm why did they hit ok?)
290 if(app.name() == application.nameLineEdit->text() && 295 if(app.name() == application.nameLineEdit->text() &&
291 app.pixmapString() == application.iconLineEdit->text() && 296 app.pixmapString() == application.iconLineEdit->text() &&
292 app.comment() == application.commentLineEdit->text() && 297 app.comment() == application.commentLineEdit->text() &&
293 app.exec() == application.execLineEdit->text()) 298 app.exec() == application.execLineEdit->text())
294 return; 299 return;
295 300
296 // Change the applnk file 301 // Change the applnk file
297 QString oldName = app.name(); 302 QString oldName = app.name();
298 app.setName(application.nameLineEdit->text()); 303 app.setName(application.nameLineEdit->text());
299 app.setIcon(application.iconLineEdit->text()); 304 app.setIcon(application.iconLineEdit->text());
300 app.setComment(application.commentLineEdit->text()); 305 app.setComment(application.commentLineEdit->text());
301 app.setExec(application.execLineEdit->text()); 306 app.setExec(application.execLineEdit->text());
302 if(!app.writeLink()){ 307 if(!app.writeLink()){
303 QMessageBox::critical(this, "Message", "Can't save.",QString("Ok") ); 308 QMessageBox::critical(this, tr("Message"), tr("Can't save."),
309 tr("Ok") );
304 return; 310 return;
305 } 311 }
306 312
307 // Update the gui icon and name 313 // Update the gui icon and name
308 item->setText(0,app.name()); 314 item->setText(0,app.name());
309 item->setPixmap(0,app.pixmap()); 315 item->setPixmap(0,app.pixmap());
310 316
311 // We have changed something. 317 // We have changed something.
312 changed = true; 318 changed = true;
313 319
314 // If we were dealing with a new folder or new application change 320 // If we were dealing with a new folder or new application change
315 // the file names. Also change the item location in itemList 321 // the file names. Also change the item location in itemList
316 if(oldName == NEW_FOLDER){ 322 if(oldName == NEW_FOLDER){
317 QDir r; 323 QDir r;
318 QString oldName = itemList[item]; 324 QString oldName = itemList[item];
319 oldName = oldName.mid(0,oldName.length()-11); 325 oldName = oldName.mid(0,oldName.length()-11);
320 QString newName = oldName.mid(0,oldName.length()-9); 326 QString newName = oldName.mid(0,oldName.length()-9);
321 newName = newName + "/" + app.name(); 327 newName = newName + "/" + app.name();
322 r.rename(oldName, newName); 328 r.rename(oldName, newName);
323 itemList.remove(item); 329 itemList.remove(item);
324 itemList.insert(item, newName + "/.directory" ); 330 itemList.insert(item, newName + "/.directory" );
325 } 331 }
326 else if(oldName == NEW_APPLICATION){ 332 else if(oldName == NEW_APPLICATION){
327 if(!item->parent()) 333 if(!item->parent())
@@ -343,49 +349,50 @@ void TabManager::editItem( QListViewItem * item){
343 * @param item the application to move 349 * @param item the application to move
344 * @pearam newGroup the new parent of this application 350 * @pearam newGroup the new parent of this application
345 */ 351 */
346void TabManager::moveApplication(QListViewItem *item, QListViewItem *newGroup){ 352void TabManager::moveApplication(QListViewItem *item, QListViewItem *newGroup){
347 // Can we even move it? 353 // Can we even move it?
348 if(!item || !item->parent() || newGroup->parent()) 354 if(!item || !item->parent() || newGroup->parent())
349 return; 355 return;
350 if(item->parent() == newGroup) 356 if(item->parent() == newGroup)
351 return; 357 return;
352 358
353 // Get the new folder, new file name, 359 // Get the new folder, new file name,
354 QString newFolder = itemList[newGroup]; 360 QString newFolder = itemList[newGroup];
355 newFolder = newFolder.mid(0,newFolder.length()-11); 361 newFolder = newFolder.mid(0,newFolder.length()-11);
356 int slash = newFolder.findRev('/', -1); 362 int slash = newFolder.findRev('/', -1);
357 QString folderName = newFolder.mid(slash+1, newFolder.length()); 363 QString folderName = newFolder.mid(slash+1, newFolder.length());
358 364
359 QString desktopFile = itemList[item]; 365 QString desktopFile = itemList[item];
360 slash = desktopFile.findRev('/', -1); 366 slash = desktopFile.findRev('/', -1);
361 desktopFile = desktopFile.mid(slash, desktopFile.length()); 367 desktopFile = desktopFile.mid(slash, desktopFile.length());
362 newFolder = newFolder + desktopFile; 368 newFolder = newFolder + desktopFile;
363 369
364 // Move file 370 // Move file
365 QDir r; 371 QDir r;
366 if(!r.rename(itemList[item], newFolder)){ 372 if(!r.rename(itemList[item], newFolder)){
367 QMessageBox::critical(this, "Message", "Can't move application.",QString("Ok") ); 373 QMessageBox::critical(this, tr("Message"), tr("Can't move application."),
374 tr("Ok") );
368 return; 375 return;
369 } 376 }
370 //qDebug((QString("moveApplication: ") + itemList[item]).latin1()); 377 //qDebug((QString("moveApplication: ") + itemList[item]).latin1());
371 //qDebug((QString("moveApplication: ") + newFolder).latin1()); 378 //qDebug((QString("moveApplication: ") + newFolder).latin1());
372 379
373 // Move in the gui 380 // Move in the gui
374 item->parent()->takeItem(item); 381 item->parent()->takeItem(item);
375 newGroup->insertItem(item); 382 newGroup->insertItem(item);
376 newGroup->setOpen(true); 383 newGroup->setOpen(true);
377 384
378 // Move file in the installer 385 // Move file in the installer
379 QString installedAppFile; 386 QString installedAppFile;
380 if(findInstalledApplication(desktopFile, installedAppFile)) 387 if(findInstalledApplication(desktopFile, installedAppFile))
381 swapInstalledLocation(installedAppFile, desktopFile, newFolder); 388 swapInstalledLocation(installedAppFile, desktopFile, newFolder);
382 else 389 else
383 qDebug("moveApplication: No installed app found for dekstop file"); 390 qDebug("moveApplication: No installed app found for dekstop file");
384 391
385 // Move application type 392 // Move application type
386 AppLnk app(newFolder); 393 AppLnk app(newFolder);
387 app.setType(folderName); 394 app.setType(folderName);
388 app.writeLink(); 395 app.writeLink();
389 396
390 // Move in our internal list 397 // Move in our internal list
391 itemList.remove(item); 398 itemList.remove(item);