author | llornkcor <llornkcor> | 2002-10-17 03:47:16 (UTC) |
---|---|---|
committer | llornkcor <llornkcor> | 2002-10-17 03:47:16 (UTC) |
commit | 8f6dc7fd4aca312bc615bf4f85755b82d29b250d (patch) (unidiff) | |
tree | 34e9be456b07b7678a3d4b812eec8471317fe641 | |
parent | 11cde43ced1c85ad350cd32ca72b75dcfbce5fce (diff) | |
download | opie-8f6dc7fd4aca312bc615bf4f85755b82d29b250d.zip opie-8f6dc7fd4aca312bc615bf4f85755b82d29b250d.tar.gz opie-8f6dc7fd4aca312bc615bf4f85755b82d29b250d.tar.bz2 |
force removal of desktop file when deleting note
-rw-r--r-- | noncore/applets/notesapplet/notes.cpp | 30 |
1 files changed, 23 insertions, 7 deletions
diff --git a/noncore/applets/notesapplet/notes.cpp b/noncore/applets/notesapplet/notes.cpp index 92fdb0a..90c2550 100644 --- a/noncore/applets/notesapplet/notes.cpp +++ b/noncore/applets/notesapplet/notes.cpp | |||
@@ -66,48 +66,49 @@ static char * notes_xpm[] = { | |||
66 | " ... ", | 66 | " ... ", |
67 | " .+ ", | 67 | " .+ ", |
68 | " .@. ", | 68 | " .@. ", |
69 | " . .+ ", | 69 | " . .+ ", |
70 | " ..#.@. ", | 70 | " ..#.@. ", |
71 | " ..###.+.. ", | 71 | " ..###.+.. ", |
72 | " ..###$...##.. ", | 72 | " ..###$...##.. ", |
73 | "..###$$$%+$$##&.", | 73 | "..###$$$%+$$##&.", |
74 | ".*=####$-###&=&.", | 74 | ".*=####$-###&=&.", |
75 | ".=**=###==&=&=..", | 75 | ".=**=###==&=&=..", |
76 | " ..=**=#&=&=.. ", | 76 | " ..=**=#&=&=.. ", |
77 | " ..=*=&=.. ", | 77 | " ..=*=&=.. ", |
78 | " ..=.. ", | 78 | " ..=.. ", |
79 | " . "}; | 79 | " . "}; |
80 | 80 | ||
81 | 81 | ||
82 | NotesControl::NotesControl( QWidget *parent, const char *name ) | 82 | NotesControl::NotesControl( QWidget *parent, const char *name ) |
83 | : QFrame( parent, name,/* WDestructiveClose | */WStyle_StaysOnTop ) | 83 | : QFrame( parent, name,/* WDestructiveClose | */WStyle_StaysOnTop ) |
84 | // : QFrame( parent, name, WDestructiveClose | WStyle_StaysOnTop | WType_Popup ) | 84 | // : QFrame( parent, name, WDestructiveClose | WStyle_StaysOnTop | WType_Popup ) |
85 | { | 85 | { |
86 | setFrameStyle( QFrame::PopupPanel | QFrame::Raised ); | 86 | setFrameStyle( QFrame::PopupPanel | QFrame::Raised ); |
87 | loaded=false; | 87 | loaded=false; |
88 | edited=false; | 88 | edited=false; |
89 | doPopulate=true; | 89 | doPopulate=true; |
90 | isNew=false; | ||
90 | QVBoxLayout *vbox = new QVBoxLayout( this,0, -1, "Vlayout" ); | 91 | QVBoxLayout *vbox = new QVBoxLayout( this,0, -1, "Vlayout" ); |
91 | QHBoxLayout *hbox = new QHBoxLayout( this, 0, -1, "HLayout" ); | 92 | QHBoxLayout *hbox = new QHBoxLayout( this, 0, -1, "HLayout" ); |
92 | 93 | ||
93 | view = new QMultiLineEdit(this, "OpieNotesView"); | 94 | view = new QMultiLineEdit(this, "OpieNotesView"); |
94 | 95 | ||
95 | box = new QListBox(this, "OpieNotesBox"); | 96 | box = new QListBox(this, "OpieNotesBox"); |
96 | 97 | ||
97 | QPEApplication::setStylusOperation( box->viewport(),QPEApplication::RightOnHold); | 98 | QPEApplication::setStylusOperation( box->viewport(),QPEApplication::RightOnHold); |
98 | 99 | ||
99 | box->setFixedHeight(50); | 100 | box->setFixedHeight(50); |
100 | 101 | ||
101 | vbox->setMargin( 6 ); | 102 | vbox->setMargin( 6 ); |
102 | vbox->setSpacing( 3 ); | 103 | vbox->setSpacing( 3 ); |
103 | 104 | ||
104 | vbox->addWidget( view); | 105 | vbox->addWidget( view); |
105 | vbox->addWidget( box); | 106 | vbox->addWidget( box); |
106 | 107 | ||
107 | setFixedHeight(180); | 108 | setFixedHeight(180); |
108 | QWidget *wid = QPEApplication::desktop(); | 109 | QWidget *wid = QPEApplication::desktop(); |
109 | setFixedWidth( wid->width()-10 /*200*/); | 110 | setFixedWidth( wid->width()-10 /*200*/); |
110 | 111 | ||
111 | setFocusPolicy(QWidget::StrongFocus); | 112 | setFocusPolicy(QWidget::StrongFocus); |
112 | 113 | ||
113 | newButton= new QPushButton( this, "newButton" ); | 114 | newButton= new QPushButton( this, "newButton" ); |
@@ -166,58 +167,68 @@ void NotesControl::slotDeleteButton() { | |||
166 | if( !selectedText.isEmpty()) { | 167 | if( !selectedText.isEmpty()) { |
167 | 168 | ||
168 | Config cfg("Notes"); | 169 | Config cfg("Notes"); |
169 | cfg.setGroup("Docs"); | 170 | cfg.setGroup("Docs"); |
170 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | 171 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); |
171 | QString entryName, entryName2;; | 172 | QString entryName, entryName2;; |
172 | for ( int i = 0; i < noOfFiles; i++ ) { | 173 | for ( int i = 0; i < noOfFiles; i++ ) { |
173 | entryName.sprintf( "File%i", i + 1 ); | 174 | entryName.sprintf( "File%i", i + 1 ); |
174 | if(selectedText == cfg.readEntry( entryName )) { | 175 | if(selectedText == cfg.readEntry( entryName )) { |
175 | qDebug("removing %s, %d", selectedText.latin1(), i); | 176 | qDebug("removing %s, %d", selectedText.latin1(), i); |
176 | for ( int j = i; j < noOfFiles; j++ ) { | 177 | for ( int j = i; j < noOfFiles; j++ ) { |
177 | entryName.sprintf( "File%i", i + 1 ); | 178 | entryName.sprintf( "File%i", i + 1 ); |
178 | entryName2.sprintf( "File%i", i + 2 ); | 179 | entryName2.sprintf( "File%i", i + 2 ); |
179 | QString temp = cfg.readEntry(entryName2); | 180 | QString temp = cfg.readEntry(entryName2); |
180 | qDebug("move "+temp); | 181 | qDebug("move "+temp); |
181 | cfg.writeEntry(entryName, temp); | 182 | cfg.writeEntry(entryName, temp); |
182 | i++; | 183 | i++; |
183 | } | 184 | } |
184 | cfg.writeEntry("NumberOfFiles", noOfFiles-1 ); | 185 | cfg.writeEntry("NumberOfFiles", noOfFiles-1 ); |
185 | entryName.sprintf( "File%i", noOfFiles ); | 186 | entryName.sprintf( "File%i", noOfFiles ); |
186 | cfg.removeEntry(entryName); | 187 | cfg.removeEntry(entryName); |
187 | cfg.write(); | 188 | cfg.write(); |
188 | DocLnk nf(selectedText); | 189 | DocLnk nf(selectedText); |
189 | nf.removeFiles(); | 190 | nf.removeFiles(); |
191 | QString fi=QPEApplication::documentDir()+"/text/plain/"+selectedText+".desktop"; | ||
192 | qDebug(fi); | ||
193 | |||
194 | QFile f( fi); | ||
195 | if( !f.remove()) qDebug(".desktop file not removed"); | ||
196 | |||
190 | } | 197 | } |
191 | } | 198 | } |
199 | view->clear(); | ||
200 | |||
192 | populateBox(); | 201 | populateBox(); |
193 | } | 202 | } |
194 | } | 203 | } |
195 | 204 | ||
196 | void NotesControl::slotNewButton() { | 205 | void NotesControl::slotNewButton() { |
197 | if(edited) save(); | 206 | if(edited) save(); |
198 | view->clear(); | 207 | view->clear(); |
199 | view->setFocus(); | 208 | view->setFocus(); |
209 | edited=false; | ||
210 | isNew=false; | ||
200 | } | 211 | } |
201 | 212 | ||
202 | void NotesControl::slotBeamButton() { | 213 | void NotesControl::slotBeamButton() { |
203 | Ir ir; | 214 | Ir ir; |
204 | if(!ir.supported()){ | 215 | if(!ir.supported()){ |
205 | } else { | 216 | } else { |
206 | this->hide(); | 217 | this->hide(); |
207 | QString selectedText = box->currentText(); | 218 | QString selectedText = box->currentText(); |
208 | if( !selectedText.isEmpty()) { | 219 | if( !selectedText.isEmpty()) { |
209 | QString file = QDir::homeDirPath()+"/"+selectedText; | 220 | QString file = QDir::homeDirPath()+"/"+selectedText; |
210 | QFile f(file); | 221 | QFile f(file); |
211 | Ir *irFile = new Ir(this, "IR"); | 222 | Ir *irFile = new Ir(this, "IR"); |
212 | connect( irFile, SIGNAL(done(Ir*)), this, SLOT( slotBeamFinished( Ir * ))); | 223 | connect( irFile, SIGNAL(done(Ir*)), this, SLOT( slotBeamFinished( Ir * ))); |
213 | irFile->send( file, "Note", "text/plain" ); | 224 | irFile->send( file, "Note", "text/plain" ); |
214 | } | 225 | } |
215 | } | 226 | } |
216 | } | 227 | } |
217 | 228 | ||
218 | void NotesControl::slotBeamFinished(Ir *) { | 229 | void NotesControl::slotBeamFinished(Ir *) { |
219 | this->show(); | 230 | this->show(); |
220 | } | 231 | } |
221 | 232 | ||
222 | void NotesControl::boxPressed(int mouse, QListBoxItem *, const QPoint&) { | 233 | void NotesControl::boxPressed(int mouse, QListBoxItem *, const QPoint&) { |
223 | switch (mouse) { | 234 | switch (mouse) { |
@@ -248,83 +259,88 @@ void NotesControl::showMenu() { | |||
248 | m->insertItem( tr( "Delete" ), this, SLOT( slotDeleteButton() )); | 259 | m->insertItem( tr( "Delete" ), this, SLOT( slotDeleteButton() )); |
249 | m->setFocus(); | 260 | m->setFocus(); |
250 | m->exec( QCursor::pos() ); | 261 | m->exec( QCursor::pos() ); |
251 | 262 | ||
252 | if(m) delete m; | 263 | if(m) delete m; |
253 | 264 | ||
254 | } | 265 | } |
255 | 266 | ||
256 | void NotesControl::focusOutEvent ( QFocusEvent * e) { | 267 | void NotesControl::focusOutEvent ( QFocusEvent * e) { |
257 | if( e->reason() == QFocusEvent::Popup) | 268 | if( e->reason() == QFocusEvent::Popup) |
258 | save(); | 269 | save(); |
259 | else { | 270 | else { |
260 | if(!loaded) { | 271 | if(!loaded) { |
261 | populateBox(); | 272 | populateBox(); |
262 | load(); | 273 | load(); |
263 | } | 274 | } |
264 | } | 275 | } |
265 | QWidget::focusOutEvent(e); | 276 | QWidget::focusOutEvent(e); |
266 | } | 277 | } |
267 | 278 | ||
268 | void NotesControl::save() { | 279 | void NotesControl::save() { |
269 | Config cfg("Notes"); | 280 | Config cfg("Notes"); |
270 | cfg.setGroup("Docs"); | 281 | cfg.setGroup("Docs"); |
271 | if( edited) { | 282 | if( edited) { |
283 | // qDebug("is edited"); | ||
272 | QString rt = view->text(); | 284 | QString rt = view->text(); |
273 | if(!rt.isEmpty()) { | 285 | if( rt.length()>1) { |
274 | QString pt = rt.simplifyWhiteSpace(); | 286 | QString pt = rt.simplifyWhiteSpace(); |
275 | int i = pt.find( ' ' ); | 287 | int i = pt.find( ' ' ); |
276 | QString docname = pt; | 288 | QString docname = pt; |
277 | if ( i > 0 ) | 289 | if ( i > 0 ) |
278 | docname = pt.left( i ); | 290 | docname = pt.left( i ); |
279 | // remove "." at the beginning | 291 | // remove "." at the beginning |
280 | while( docname.startsWith( "." ) ) | 292 | while( docname.startsWith( "." ) ) |
281 | docname = docname.mid( 1 ); | 293 | docname = docname.mid( 1 ); |
282 | docname.replace( QRegExp("/"), "_" ); | 294 | docname.replace( QRegExp("/"), "_" ); |
283 | // cut the length. filenames longer than that don't make sense | 295 | // cut the length. filenames longer than that don't make sense |
284 | // and something goes wrong when they get too long. | 296 | // and something goes wrong when they get too long. |
285 | if ( docname.length() > 40 ) | 297 | if ( docname.length() > 40 ) |
286 | docname = docname.left(40); | 298 | docname = docname.left(40); |
287 | if ( docname.isEmpty() ) | 299 | if ( docname.isEmpty() ) |
288 | docname = "Empty Text"; | 300 | docname = "Empty Text"; |
289 | qDebug(docname); | 301 | // qDebug(docname); |
290 | 302 | ||
291 | if( oldDocName != docname) { | 303 | if( oldDocName != docname) { |
292 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | 304 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); |
293 | QString entryName; | 305 | QString entryName; |
294 | entryName.sprintf( "File%i", noOfFiles + 1 ); | 306 | entryName.sprintf( "File%i", noOfFiles + 1 ); |
295 | cfg.writeEntry( entryName,docname ); | 307 | cfg.writeEntry( entryName,docname ); |
296 | cfg.writeEntry("NumberOfFiles", noOfFiles+1 ); | 308 | cfg.writeEntry("NumberOfFiles", noOfFiles+1 ); |
297 | cfg.write(); | 309 | cfg.write(); |
298 | } | 310 | } |
299 | else | 311 | // else |
300 | qDebug("oldname equals docname"); | 312 | // qDebug("oldname equals docname"); |
313 | |||
314 | |||
301 | doc = new DocLnk(docname); | 315 | doc = new DocLnk(docname); |
302 | 316 | ||
317 | if(QFile(doc->linkFile()).exists()) | ||
318 | qDebug("puppie"); | ||
303 | doc->setType("text/plain"); | 319 | doc->setType("text/plain"); |
304 | doc->setFile(docname); | 320 | doc->setFile(QDir::homeDirPath()+"/"+docname); |
305 | doc->setName(docname); | 321 | doc->setName(docname); |
306 | 322 | ||
307 | FileManager fm; | 323 | FileManager fm; |
308 | if ( !fm.saveFile( *doc, rt ) ) { | 324 | if ( !fm.saveFile( *doc, rt ) ) { |
309 | } | 325 | } |
310 | 326 | ||
311 | oldDocName=docname; | 327 | oldDocName=docname; |
312 | edited=false; | 328 | edited=false; |
313 | // qDebug("save"); | 329 | // qDebug("save"); |
314 | if (doPopulate) | 330 | if (doPopulate) |
315 | populateBox(); | 331 | populateBox(); |
316 | } | 332 | } |
317 | cfg.writeEntry( "LastDoc",oldDocName ); | 333 | cfg.writeEntry( "LastDoc",oldDocName ); |
318 | cfg.write(); | 334 | cfg.write(); |
319 | 335 | ||
320 | } | 336 | } |
321 | } | 337 | } |
322 | 338 | ||
323 | void NotesControl::populateBox() { | 339 | void NotesControl::populateBox() { |
324 | box->clear(); | 340 | box->clear(); |
325 | // qDebug("populate"); | 341 | // qDebug("populate"); |
326 | Config cfg("Notes"); | 342 | Config cfg("Notes"); |
327 | cfg.setGroup("Docs"); | 343 | cfg.setGroup("Docs"); |
328 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); | 344 | int noOfFiles = cfg.readNumEntry("NumberOfFiles", 0 ); |
329 | QStringList list; | 345 | QStringList list; |
330 | QString entryName; | 346 | QString entryName; |