summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--library/lnkproperties.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/library/lnkproperties.cpp b/library/lnkproperties.cpp
index 50cf5af..8dca4ab 100644
--- a/library/lnkproperties.cpp
+++ b/library/lnkproperties.cpp
@@ -42,48 +42,53 @@
42#include <qpushbutton.h> 42#include <qpushbutton.h>
43#include <qgroupbox.h> 43#include <qgroupbox.h>
44#include <qcheckbox.h> 44#include <qcheckbox.h>
45#include <qlabel.h> 45#include <qlabel.h>
46#include <qlayout.h> 46#include <qlayout.h>
47#include <qfile.h> 47#include <qfile.h>
48#include <qfileinfo.h> 48#include <qfileinfo.h>
49#include <qmessagebox.h> 49#include <qmessagebox.h>
50#include <qsize.h> 50#include <qsize.h>
51#include <qcombobox.h> 51#include <qcombobox.h>
52#include <qregexp.h> 52#include <qregexp.h>
53#include <qbuttongroup.h> 53#include <qbuttongroup.h>
54 54
55#include <stdlib.h> 55#include <stdlib.h>
56 56
57LnkProperties::LnkProperties( AppLnk* l, QWidget* parent ) 57LnkProperties::LnkProperties( AppLnk* l, QWidget* parent )
58 : QDialog( parent, 0, TRUE ), lnk(l), fileSize( 0 ) 58 : QDialog( parent, 0, TRUE ), lnk(l), fileSize( 0 )
59{ 59{
60 setCaption( tr("Properties") ); 60 setCaption( tr("Properties") );
61 61
62 QVBoxLayout *vbox = new QVBoxLayout( this ); 62 QVBoxLayout *vbox = new QVBoxLayout( this );
63 d = new LnkPropertiesBase( this ); 63 d = new LnkPropertiesBase( this );
64 vbox->add( d ); 64 vbox->add( d );
65 65
66 // hide custom rotation feature for now, need a new implementation to fit quicklauch,
67 // is confusing for the user and doubtable useful since life rotation
68 d->rotate->hide();
69 d->rotateButtons->hide();
70
66 d->docname->setText(l->name()); 71 d->docname->setText(l->name());
67 QString inf; 72 QString inf;
68 if ( l->type().isEmpty() ) { 73 if ( l->type().isEmpty() ) {
69 d->type->hide(); 74 d->type->hide();
70 d->typeLabel->hide(); 75 d->typeLabel->hide();
71 } else { 76 } else {
72 d->type->setText( l->type() ); 77 d->type->setText( l->type() );
73 } 78 }
74 79
75 if ( l->comment().isEmpty() ) { 80 if ( l->comment().isEmpty() ) {
76 d->comment->hide(); 81 d->comment->hide();
77 d->commentLabel->hide(); 82 d->commentLabel->hide();
78 } else { 83 } else {
79 d->comment->setText( l->comment() ); 84 d->comment->setText( l->comment() );
80 } 85 }
81 86
82 connect(d->beam,SIGNAL(clicked()),this,SLOT(beamLnk())); 87 connect(d->beam,SIGNAL(clicked()),this,SLOT(beamLnk()));
83 if ( lnk->type().contains('/') ) { // A document? (#### better predicate needed) 88 if ( lnk->type().contains('/') ) { // A document? (#### better predicate needed)
84 connect(d->unlink,SIGNAL(clicked()),this,SLOT(unlinkLnk())); 89 connect(d->unlink,SIGNAL(clicked()),this,SLOT(unlinkLnk()));
85 connect(d->duplicate,SIGNAL(clicked()),this,SLOT(duplicateLnk())); 90 connect(d->duplicate,SIGNAL(clicked()),this,SLOT(duplicateLnk()));
86 91
87 d->docname->setReadOnly( FALSE ); 92 d->docname->setReadOnly( FALSE );
88 d->preload->hide(); 93 d->preload->hide();
89 d->rotate->hide(); 94 d->rotate->hide();
@@ -94,49 +99,50 @@ LnkProperties::LnkProperties( AppLnk* l, QWidget* parent )
94 d->categoryEdit->kludge(); 99 d->categoryEdit->kludge();
95 100
96 d->categoryEdit->setCategories( lnk->categories(), 101 d->categoryEdit->setCategories( lnk->categories(),
97 "Document View", 102 "Document View",
98 tr("Document View") ); 103 tr("Document View") );
99 setupLocations(); 104 setupLocations();
100 } else { 105 } else {
101 d->unlink->hide(); 106 d->unlink->hide();
102 d->duplicate->hide(); 107 d->duplicate->hide();
103 d->beam->hide(); 108 d->beam->hide();
104 d->hline->hide(); 109 d->hline->hide();
105 d->locationLabel->hide(); 110 d->locationLabel->hide();
106 d->locationCombo->hide(); 111 d->locationCombo->hide();
107 112
108 // Can't edit categories, since the app .desktop files are global, 113 // Can't edit categories, since the app .desktop files are global,
109 // possibly read-only. 114 // possibly read-only.
110 d->categoryEdit->hide(); 115 d->categoryEdit->hide();
111 116
112 d->docname->setReadOnly( TRUE ); 117 d->docname->setReadOnly( TRUE );
113 118
114 if ( l->property("CanFastload") == "0" ) 119 if ( l->property("CanFastload") == "0" )
115 d->preload->hide(); 120 d->preload->hide();
116 if ( !l->property("Rotation"). isEmpty ()) { 121 if ( !l->property("Rotation"). isEmpty ()) {
117 d->rotate->setChecked ( true ); 122 d->rotate->setChecked ( true );
118 d->rotateButtons->setButton((l->rotation().toInt()%360)/90); 123 //don't use rotate buttons for now (see comment above)
124 //d->rotateButtons->setButton((l->rotation().toInt()%360)/90);
119 } 125 }
120 else { 126 else {
121 d->rotateButtons->setEnabled(false); 127 d->rotateButtons->setEnabled(false);
122 } 128 }
123 129
124 Config cfg("Launcher"); 130 Config cfg("Launcher");
125 cfg.setGroup("Preload"); 131 cfg.setGroup("Preload");
126 QStringList apps = cfg.readListEntry("Apps",','); 132 QStringList apps = cfg.readListEntry("Apps",',');
127 d->preload->setChecked( apps.contains(l->exec()) ); 133 d->preload->setChecked( apps.contains(l->exec()) );
128 if ( Global::isBuiltinCommand(lnk->exec()) ) 134 if ( Global::isBuiltinCommand(lnk->exec()) )
129 d->preload->hide(); // builtins are always fast 135 d->preload->hide(); // builtins are always fast
130 136
131 currentLocation = 0; // apps not movable (yet) 137 currentLocation = 0; // apps not movable (yet)
132 } 138 }
133} 139}
134 140
135LnkProperties::~LnkProperties() 141LnkProperties::~LnkProperties()
136{ 142{
137} 143}
138 144
139void LnkProperties::unlinkLnk() 145void LnkProperties::unlinkLnk()
140{ 146{
141 if ( QPEMessageBox::confirmDelete( this, tr("Delete"), lnk->name() ) ) { 147 if ( QPEMessageBox::confirmDelete( this, tr("Delete"), lnk->name() ) ) {
142 lnk->removeFiles(); 148 lnk->removeFiles();
@@ -148,48 +154,49 @@ void LnkProperties::unlinkLnk()
148 } 154 }
149} 155}
150 156
151void LnkProperties::setupLocations() 157void LnkProperties::setupLocations()
152{ 158{
153 QFileInfo fi( lnk->file() ); 159 QFileInfo fi( lnk->file() );
154 fileSize = fi.size(); 160 fileSize = fi.size();
155 StorageInfo storage; 161 StorageInfo storage;
156 const QList<FileSystem> &fs = storage.fileSystems(); 162 const QList<FileSystem> &fs = storage.fileSystems();
157 QListIterator<FileSystem> it ( fs ); 163 QListIterator<FileSystem> it ( fs );
158 QString s; 164 QString s;
159 QString homeDir = getenv("HOME"); 165 QString homeDir = getenv("HOME");
160 QString hardDiskHome; 166 QString hardDiskHome;
161 QString hardDiskPath; 167 QString hardDiskPath;
162 int index = 0; 168 int index = 0;
163 currentLocation = -1; 169 currentLocation = -1;
164 for ( ; it.current(); ++it ) { 170 for ( ; it.current(); ++it ) {
165 // we add 10k to the file size so we are sure we can also save the desktop file 171 // we add 10k to the file size so we are sure we can also save the desktop file
166 if ( (ulong)(*it)->availBlocks() * (ulong)(*it)->blockSize() > (ulong)fileSize + 10000 ) { 172 if ( (ulong)(*it)->availBlocks() * (ulong)(*it)->blockSize() > (ulong)fileSize + 10000 ) {
167 if ( (*it)->isRemovable() || 173 if ( (*it)->isRemovable() ||
168 (*it)->disk() == "/dev/mtdblock1" || 174 (*it)->disk() == "/dev/mtdblock1" ||
169 (*it)->disk() == "/dev/mtdblock/1" || 175 (*it)->disk() == "/dev/mtdblock/1" ||
170 (*it)->disk().left(13) == "/dev/mtdblock" || 176 (*it)->disk().left(13) == "/dev/mtdblock" ||
171 (*it)->disk() == "/dev/mtdblock6" || 177 (*it)->disk() == "/dev/mtdblock6" ||
178 (*it )->disk() == "/dev/root" ||
172 (*it)->disk() == "tmpfs" ) { 179 (*it)->disk() == "tmpfs" ) {
173 d->locationCombo->insertItem( (*it)->name(), index ); 180 d->locationCombo->insertItem( (*it)->name(), index );
174 locations.append( ( ((*it)->isRemovable() || 181 locations.append( ( ((*it)->isRemovable() ||
175 (*it)->disk() == "/dev/mtdblock6" || 182 (*it)->disk() == "/dev/mtdblock6" ||
176 (*it)->disk() == "tmpfs" ) 183 (*it)->disk() == "tmpfs" )
177 ? (*it)->path() : homeDir) ); 184 ? (*it)->path() : homeDir) );
178 if ( lnk->file().contains( (*it)->path() ) ) { 185 if ( lnk->file().contains( (*it)->path() ) ) {
179 d->locationCombo->setCurrentItem( index ); 186 d->locationCombo->setCurrentItem( index );
180 currentLocation = index; 187 currentLocation = index;
181 } 188 }
182 index++; 189 index++;
183 } else if ( (*it)->name().contains( tr("Hard Disk") ) && 190 } else if ( (*it)->name().contains( tr("Hard Disk") ) &&
184 homeDir.contains( (*it)->path() ) && 191 homeDir.contains( (*it)->path() ) &&
185 (*it)->path().length() > hardDiskHome.length() ) { 192 (*it)->path().length() > hardDiskHome.length() ) {
186 hardDiskHome = (*it)->name(); 193 hardDiskHome = (*it)->name();
187 hardDiskPath = (*it)->path(); 194 hardDiskPath = (*it)->path();
188 } 195 }
189 } 196 }
190 } 197 }
191 if ( !hardDiskHome.isEmpty() ) { 198 if ( !hardDiskHome.isEmpty() ) {
192 d->locationCombo->insertItem( hardDiskHome ); 199 d->locationCombo->insertItem( hardDiskHome );
193 locations.append( hardDiskPath ); 200 locations.append( hardDiskPath );
194 if ( currentLocation == -1 ) { // assume it's the hard disk 201 if ( currentLocation == -1 ) { // assume it's the hard disk
195 d->locationCombo->setCurrentItem( index ); 202 d->locationCombo->setCurrentItem( index );