summaryrefslogtreecommitdiffabout
authorzautrix <zautrix>2005-06-30 04:58:35 (UTC)
committer zautrix <zautrix>2005-06-30 04:58:35 (UTC)
commitba4a6a95356f9a8044257c45347cee8b15667d0c (patch) (unidiff)
tree63ffa2000426f06cae7ec5be7d1847b5f9fb4e26
parent63147898391dbeabca2dc8f48730b324c15a7498 (diff)
downloadkdepimpi-ba4a6a95356f9a8044257c45347cee8b15667d0c.zip
kdepimpi-ba4a6a95356f9a8044257c45347cee8b15667d0c.tar.gz
kdepimpi-ba4a6a95356f9a8044257c45347cee8b15667d0c.tar.bz2
fixxx
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--microkde/kdeui/klistview.cpp9
-rw-r--r--microkde/kdeui/klistview.h1
2 files changed, 10 insertions, 0 deletions
diff --git a/microkde/kdeui/klistview.cpp b/microkde/kdeui/klistview.cpp
index 25327aa..f7d2187 100644
--- a/microkde/kdeui/klistview.cpp
+++ b/microkde/kdeui/klistview.cpp
@@ -95,769 +95,778 @@ public:
95 selectedBySimpleMove(false), 95 selectedBySimpleMove(false),
96 selectedUsingMouse(false), 96 selectedUsingMouse(false),
97 itemsRenameable (false), 97 itemsRenameable (false),
98 validDrag (false), 98 validDrag (false),
99 dragEnabled (false), 99 dragEnabled (false),
100 autoOpen (true), 100 autoOpen (true),
101 dropVisualizer (true), 101 dropVisualizer (true),
102 dropHighlighter (false), 102 dropHighlighter (false),
103 createChildren (true), 103 createChildren (true),
104 pressedOnSelected (false), 104 pressedOnSelected (false),
105 wasShiftEvent (false), 105 wasShiftEvent (false),
106 fullWidth (false), 106 fullWidth (false),
107 sortAscending(true), 107 sortAscending(true),
108 tabRename(true), 108 tabRename(true),
109 sortColumn(0), 109 sortColumn(0),
110 selectionDirection(0), 110 selectionDirection(0),
111 tooltipColumn (0), 111 tooltipColumn (0),
112 selectionMode (Single), 112 selectionMode (Single),
113 contextMenuKey ( Qt::Key_Menu ),//KGlobalSettings::contextMenuKey()), 113 contextMenuKey ( Qt::Key_Menu ),//KGlobalSettings::contextMenuKey()),
114 showContextMenusOnPress (true),//showContextMenusOnPress (KGlobalSettings::showContextMenusOnPress()), 114 showContextMenusOnPress (true),//showContextMenusOnPress (KGlobalSettings::showContextMenusOnPress()),
115 mDropVisualizerWidth (4) 115 mDropVisualizerWidth (4)
116 { 116 {
117 renameable += 0; 117 renameable += 0;
118//US connect(editor, SIGNAL(done(QListViewItem*,int)), listview, SLOT(doneEditing(QListViewItem*,int))); 118//US connect(editor, SIGNAL(done(QListViewItem*,int)), listview, SLOT(doneEditing(QListViewItem*,int)));
119 } 119 }
120 120
121 ~KListViewPrivate () 121 ~KListViewPrivate ()
122 { 122 {
123//US delete editor; 123//US delete editor;
124 } 124 }
125 125
126 QListViewItem* pCurrentItem; 126 QListViewItem* pCurrentItem;
127 127
128 QTimer autoSelect; 128 QTimer autoSelect;
129 int autoSelectDelay; 129 int autoSelectDelay;
130 130
131 QTimer dragExpand; 131 QTimer dragExpand;
132 QListViewItem* dragOverItem; 132 QListViewItem* dragOverItem;
133 QPoint dragOverPoint; 133 QPoint dragOverPoint;
134 134
135 QPoint startDragPos; 135 QPoint startDragPos;
136 int dragDelay; 136 int dragDelay;
137 137
138//US KListViewLineEdit *editor; 138//US KListViewLineEdit *editor;
139 QValueList<int> renameable; 139 QValueList<int> renameable;
140 140
141 bool cursorInExecuteArea:1; 141 bool cursorInExecuteArea:1;
142 bool bUseSingle:1; 142 bool bUseSingle:1;
143 bool bChangeCursorOverItem:1; 143 bool bChangeCursorOverItem:1;
144 bool itemsMovable:1; 144 bool itemsMovable:1;
145 bool selectedBySimpleMove : 1; 145 bool selectedBySimpleMove : 1;
146 bool selectedUsingMouse:1; 146 bool selectedUsingMouse:1;
147 bool itemsRenameable:1; 147 bool itemsRenameable:1;
148 bool validDrag:1; 148 bool validDrag:1;
149 bool dragEnabled:1; 149 bool dragEnabled:1;
150 bool autoOpen:1; 150 bool autoOpen:1;
151 bool dropVisualizer:1; 151 bool dropVisualizer:1;
152 bool dropHighlighter:1; 152 bool dropHighlighter:1;
153 bool createChildren:1; 153 bool createChildren:1;
154 bool pressedOnSelected:1; 154 bool pressedOnSelected:1;
155 bool wasShiftEvent:1; 155 bool wasShiftEvent:1;
156 bool fullWidth:1; 156 bool fullWidth:1;
157 bool sortAscending:1; 157 bool sortAscending:1;
158 bool tabRename:1; 158 bool tabRename:1;
159 159
160 int sortColumn; 160 int sortColumn;
161 161
162 //+1 means downwards (y increases, -1 means upwards, 0 means not selected), aleXXX 162 //+1 means downwards (y increases, -1 means upwards, 0 means not selected), aleXXX
163 int selectionDirection; 163 int selectionDirection;
164 int tooltipColumn; 164 int tooltipColumn;
165 165
166 SelectionModeExt selectionMode; 166 SelectionModeExt selectionMode;
167 int contextMenuKey; 167 int contextMenuKey;
168 bool showContextMenusOnPress; 168 bool showContextMenusOnPress;
169 169
170 QRect mOldDropVisualizer; 170 QRect mOldDropVisualizer;
171 int mDropVisualizerWidth; 171 int mDropVisualizerWidth;
172 QRect mOldDropHighlighter; 172 QRect mOldDropHighlighter;
173 QListViewItem *afterItemDrop; 173 QListViewItem *afterItemDrop;
174 QListViewItem *parentItemDrop; 174 QListViewItem *parentItemDrop;
175 175
176 QColor alternateBackground; 176 QColor alternateBackground;
177}; 177};
178 178
179/*US 179/*US
180KListViewLineEdit::KListViewLineEdit(KListView *parent) 180KListViewLineEdit::KListViewLineEdit(KListView *parent)
181 : KLineEdit(parent->viewport()), item(0), col(0), p(parent) 181 : KLineEdit(parent->viewport()), item(0), col(0), p(parent)
182{ 182{
183 setFrame( false ); 183 setFrame( false );
184 hide(); 184 hide();
185 connect( parent, SIGNAL( selectionChanged() ), SLOT( slotSelectionChanged() )); 185 connect( parent, SIGNAL( selectionChanged() ), SLOT( slotSelectionChanged() ));
186} 186}
187 187
188KListViewLineEdit::~KListViewLineEdit() 188KListViewLineEdit::~KListViewLineEdit()
189{ 189{
190} 190}
191 191
192void KListViewLineEdit::load(QListViewItem *i, int c) 192void KListViewLineEdit::load(QListViewItem *i, int c)
193{ 193{
194 item=i; 194 item=i;
195 col=c; 195 col=c;
196 196
197 QRect rect(p->itemRect(i)); 197 QRect rect(p->itemRect(i));
198 setText(item->text(c)); 198 setText(item->text(c));
199 199
200 int fieldX = rect.x() - 1; 200 int fieldX = rect.x() - 1;
201 int fieldW = p->columnWidth(col) + 2; 201 int fieldW = p->columnWidth(col) + 2;
202 202
203 int pos = p->header()->mapToIndex(col); 203 int pos = p->header()->mapToIndex(col);
204 for ( int index = 0; index < pos; index++ ) 204 for ( int index = 0; index < pos; index++ )
205 fieldX += p->columnWidth( p->header()->mapToSection( index )); 205 fieldX += p->columnWidth( p->header()->mapToSection( index ));
206 206
207 if ( col == 0 ) { 207 if ( col == 0 ) {
208 int d = i->depth() + (p->rootIsDecorated() ? 1 : 0); 208 int d = i->depth() + (p->rootIsDecorated() ? 1 : 0);
209 d *= p->treeStepSize(); 209 d *= p->treeStepSize();
210 fieldX += d; 210 fieldX += d;
211 fieldW -= d; 211 fieldW -= d;
212 } 212 }
213 213
214 if ( i->pixmap( col ) ) {// add width of pixmap 214 if ( i->pixmap( col ) ) {// add width of pixmap
215 int d = i->pixmap( col )->width(); 215 int d = i->pixmap( col )->width();
216 fieldX += d; 216 fieldX += d;
217 fieldW -= d; 217 fieldW -= d;
218 } 218 }
219 219
220 setGeometry(fieldX, rect.y() - 1, fieldW, rect.height() + 2); 220 setGeometry(fieldX, rect.y() - 1, fieldW, rect.height() + 2);
221 show(); 221 show();
222 setFocus(); 222 setFocus();
223} 223}
224*/ 224*/
225 /*Helper functions to for 225 /*Helper functions to for
226 *tabOrderedRename functionality. 226 *tabOrderedRename functionality.
227 */ 227 */
228 228
229static int nextCol (KListView *pl, QListViewItem *pi, int start, int dir) 229static int nextCol (KListView *pl, QListViewItem *pi, int start, int dir)
230{ 230{
231 if (pi) 231 if (pi)
232 { 232 {
233 //Find the next renameable column in the current row 233 //Find the next renameable column in the current row
234 for (; ((dir == +1) ? (start < pl->columns()) : (start >= 0)); start += dir) 234 for (; ((dir == +1) ? (start < pl->columns()) : (start >= 0)); start += dir)
235 if (pl->isRenameable(start)) 235 if (pl->isRenameable(start))
236 return start; 236 return start;
237 } 237 }
238 238
239 return -1; 239 return -1;
240} 240}
241 241
242static QListViewItem *prevItem (QListViewItem *pi) 242static QListViewItem *prevItem (QListViewItem *pi)
243{ 243{
244 QListViewItem *pa = pi->itemAbove(); 244 QListViewItem *pa = pi->itemAbove();
245 245
246 /*Does what the QListViewItem::previousSibling() 246 /*Does what the QListViewItem::previousSibling()
247 *of my dreams would do. 247 *of my dreams would do.
248 */ 248 */
249 if (pa && pa->parent() == pi->parent()) 249 if (pa && pa->parent() == pi->parent())
250 return pa; 250 return pa;
251 251
252 return NULL; 252 return NULL;
253} 253}
254 254
255static QListViewItem *lastQChild (QListViewItem *pi) 255static QListViewItem *lastQChild (QListViewItem *pi)
256{ 256{
257 if (pi) 257 if (pi)
258 { 258 {
259 /*Since there's no QListViewItem::lastChild(). 259 /*Since there's no QListViewItem::lastChild().
260 *This finds the last sibling for the given 260 *This finds the last sibling for the given
261 *item. 261 *item.
262 */ 262 */
263 for (QListViewItem *pt = pi->nextSibling(); pt; pt = pt->nextSibling()) 263 for (QListViewItem *pt = pi->nextSibling(); pt; pt = pt->nextSibling())
264 pi = pt; 264 pi = pt;
265 } 265 }
266 266
267 return pi; 267 return pi;
268} 268}
269/*US 269/*US
270void KListViewLineEdit::selectNextCell (QListViewItem *pitem, int column, bool forward) 270void KListViewLineEdit::selectNextCell (QListViewItem *pitem, int column, bool forward)
271{ 271{
272 const int ncols = p->columns(); 272 const int ncols = p->columns();
273 const int dir = forward ? +1 : -1; 273 const int dir = forward ? +1 : -1;
274 const int restart = forward ? 0 : (ncols - 1); 274 const int restart = forward ? 0 : (ncols - 1);
275 QListViewItem *top = (pitem && pitem->parent()) 275 QListViewItem *top = (pitem && pitem->parent())
276 ? pitem->parent()->firstChild() 276 ? pitem->parent()->firstChild()
277 : p->firstChild(); 277 : p->firstChild();
278 QListViewItem *pi = pitem; 278 QListViewItem *pi = pitem;
279 279
280 terminate(); //Save current changes 280 terminate(); //Save current changes
281 281
282 do 282 do
283 { 283 {
284*/ 284*/
285 /*Check the rest of the current row for an editable column, 285 /*Check the rest of the current row for an editable column,
286 *if that fails, check the entire next/previous row. The 286 *if that fails, check the entire next/previous row. The
287 *last case goes back to the first item in the current branch 287 *last case goes back to the first item in the current branch
288 *or the last item in the current branch depending on the 288 *or the last item in the current branch depending on the
289 *direction. 289 *direction.
290 */ 290 */
291/*US 291/*US
292 if ((column = nextCol(p, pi, column + dir, dir)) != -1 || 292 if ((column = nextCol(p, pi, column + dir, dir)) != -1 ||
293 (column = nextCol(p, (pi = (forward ? pi->nextSibling() : prevItem(pi))), restart, dir)) != -1 || 293 (column = nextCol(p, (pi = (forward ? pi->nextSibling() : prevItem(pi))), restart, dir)) != -1 ||
294 (column = nextCol(p, (pi = (forward ? top : lastQChild(pitem))), restart, dir)) != -1) 294 (column = nextCol(p, (pi = (forward ? top : lastQChild(pitem))), restart, dir)) != -1)
295 { 295 {
296 if (pi) 296 if (pi)
297 { 297 {
298 p->setCurrentItem(pi); //Calls terminate 298 p->setCurrentItem(pi); //Calls terminate
299 p->rename(pi, column); 299 p->rename(pi, column);
300*/ 300*/
301 /*Some listviews may override rename() to 301 /*Some listviews may override rename() to
302 *prevent certain items from being renamed, 302 *prevent certain items from being renamed,
303 *if this is done, [m_]item will be NULL 303 *if this is done, [m_]item will be NULL
304 *after the rename() call... try again. 304 *after the rename() call... try again.
305 */ 305 */
306/*US 306/*US
307 if (!item) 307 if (!item)
308 continue; 308 continue;
309 309
310 break; 310 break;
311 } 311 }
312 } 312 }
313 } 313 }
314 while (pi && !item); 314 while (pi && !item);
315} 315}
316*/ 316*/
317 317
318/*US 318/*US
319#ifdef KeyPress 319#ifdef KeyPress
320#undef KeyPress 320#undef KeyPress
321#endif 321#endif
322 322
323bool KListViewLineEdit::event (QEvent *pe) 323bool KListViewLineEdit::event (QEvent *pe)
324{ 324{
325 if (pe->type() == QEvent::KeyPress) 325 if (pe->type() == QEvent::KeyPress)
326 { 326 {
327 QKeyEvent *k = (QKeyEvent *) pe; 327 QKeyEvent *k = (QKeyEvent *) pe;
328 328
329 if ((k->key() == Qt::Key_Backtab || k->key() == Qt::Key_Tab) && 329 if ((k->key() == Qt::Key_Backtab || k->key() == Qt::Key_Tab) &&
330 p->tabOrderedRenaming() && p->itemsRenameable() && 330 p->tabOrderedRenaming() && p->itemsRenameable() &&
331 !(k->state() & ControlButton || k->state() & AltButton)) 331 !(k->state() & ControlButton || k->state() & AltButton))
332 { 332 {
333 selectNextCell(item, col, 333 selectNextCell(item, col,
334 (k->key() == Key_Tab && !(k->state() & ShiftButton))); 334 (k->key() == Key_Tab && !(k->state() & ShiftButton)));
335 return true; 335 return true;
336 } 336 }
337 } 337 }
338 338
339 return KLineEdit::event(pe); 339 return KLineEdit::event(pe);
340} 340}
341 341
342void KListViewLineEdit::keyPressEvent(QKeyEvent *e) 342void KListViewLineEdit::keyPressEvent(QKeyEvent *e)
343{ 343{
344 if(e->key() == Qt::Key_Return || e->key() == Qt::Key_Enter ) 344 if(e->key() == Qt::Key_Return || e->key() == Qt::Key_Enter )
345 terminate(true); 345 terminate(true);
346 else if(e->key() == Qt::Key_Escape) 346 else if(e->key() == Qt::Key_Escape)
347 terminate(false); 347 terminate(false);
348 else if (e->key() == Qt::Key_Down || e->key() == Qt::Key_Up) 348 else if (e->key() == Qt::Key_Down || e->key() == Qt::Key_Up)
349 { 349 {
350 terminate(true); 350 terminate(true);
351 KLineEdit::keyPressEvent(e); 351 KLineEdit::keyPressEvent(e);
352 } 352 }
353 else 353 else
354 KLineEdit::keyPressEvent(e); 354 KLineEdit::keyPressEvent(e);
355} 355}
356 356
357void KListViewLineEdit::terminate() 357void KListViewLineEdit::terminate()
358{ 358{
359 terminate(true); 359 terminate(true);
360} 360}
361 361
362void KListViewLineEdit::terminate(bool commit) 362void KListViewLineEdit::terminate(bool commit)
363{ 363{
364 if ( item ) 364 if ( item )
365 { 365 {
366 //kdDebug() << "KListViewLineEdit::terminate " << commit << endl; 366 //kdDebug() << "KListViewLineEdit::terminate " << commit << endl;
367 if (commit) 367 if (commit)
368 item->setText(col, text()); 368 item->setText(col, text());
369 int c=col; 369 int c=col;
370 QListViewItem *i=item; 370 QListViewItem *i=item;
371 col=0; 371 col=0;
372 item=0; 372 item=0;
373 hide(); // will call focusOutEvent, that's why we set item=0 before 373 hide(); // will call focusOutEvent, that's why we set item=0 before
374 emit done(i,c); 374 emit done(i,c);
375 } 375 }
376} 376}
377 377
378void KListViewLineEdit::focusOutEvent(QFocusEvent *ev) 378void KListViewLineEdit::focusOutEvent(QFocusEvent *ev)
379{ 379{
380 QFocusEvent * focusEv = static_cast<QFocusEvent*>(ev); 380 QFocusEvent * focusEv = static_cast<QFocusEvent*>(ev);
381 // Don't let a RMB close the editor 381 // Don't let a RMB close the editor
382 if (focusEv->reason() != QFocusEvent::Popup && focusEv->reason() != QFocusEvent::ActiveWindow) 382 if (focusEv->reason() != QFocusEvent::Popup && focusEv->reason() != QFocusEvent::ActiveWindow)
383 terminate(true); 383 terminate(true);
384} 384}
385 385
386void KListViewLineEdit::paintEvent( QPaintEvent *e ) 386void KListViewLineEdit::paintEvent( QPaintEvent *e )
387{ 387{
388 KLineEdit::paintEvent( e ); 388 KLineEdit::paintEvent( e );
389 389
390 if ( !frame() ) { 390 if ( !frame() ) {
391 QPainter p( this ); 391 QPainter p( this );
392 p.setClipRegion( e->region() ); 392 p.setClipRegion( e->region() );
393 p.drawRect( rect() ); 393 p.drawRect( rect() );
394 } 394 }
395} 395}
396 396
397// selection changed -> terminate. As our "item" can be already deleted, 397// selection changed -> terminate. As our "item" can be already deleted,
398// we can't call terminate(false), because that would emit done() with 398// we can't call terminate(false), because that would emit done() with
399// a dangling pointer to "item". 399// a dangling pointer to "item".
400void KListViewLineEdit::slotSelectionChanged() 400void KListViewLineEdit::slotSelectionChanged()
401{ 401{
402 item = 0; 402 item = 0;
403 col = 0; 403 col = 0;
404 hide(); 404 hide();
405} 405}
406*/ 406*/
407 407
408KListView::KListView( QWidget *parent, const char *name ,bool emulateRightMouse ) 408KListView::KListView( QWidget *parent, const char *name ,bool emulateRightMouse )
409 : QListView( parent, name ), 409 : QListView( parent, name ),
410 d (new KListViewPrivate (this)) 410 d (new KListViewPrivate (this))
411{ 411{
412#ifndef DESKTOP_VERSION 412#ifndef DESKTOP_VERSION
413 if ( emulateRightMouse ) 413 if ( emulateRightMouse )
414 QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold ); 414 QPEApplication::setStylusOperation( viewport(), QPEApplication::RightOnHold );
415#endif 415#endif
416//US setDragAutoScroll(true); 416//US setDragAutoScroll(true);
417 417
418 connect( this, SIGNAL( onViewport() ), 418 connect( this, SIGNAL( onViewport() ),
419 this, SLOT( slotOnViewport() ) ); 419 this, SLOT( slotOnViewport() ) );
420 connect( this, SIGNAL( onItem( QListViewItem * ) ), 420 connect( this, SIGNAL( onItem( QListViewItem * ) ),
421 this, SLOT( slotOnItem( QListViewItem * ) ) ); 421 this, SLOT( slotOnItem( QListViewItem * ) ) );
422 422
423 connect (this, SIGNAL(contentsMoving(int,int)), 423 connect (this, SIGNAL(contentsMoving(int,int)),
424 this, SLOT(cleanDropVisualizer())); 424 this, SLOT(cleanDropVisualizer()));
425 connect (this, SIGNAL(contentsMoving(int,int)), 425 connect (this, SIGNAL(contentsMoving(int,int)),
426 this, SLOT(cleanItemHighlighter())); 426 this, SLOT(cleanItemHighlighter()));
427 427
428/*US 428/*US
429 slotSettingsChanged(KApplication::SETTINGS_MOUSE); 429 slotSettingsChanged(KApplication::SETTINGS_MOUSE);
430 430
431 if (kapp) 431 if (kapp)
432 { 432 {
433 connect( kapp, SIGNAL( settingsChanged(int) ), SLOT( slotSettingsChanged(int) ) ); 433 connect( kapp, SIGNAL( settingsChanged(int) ), SLOT( slotSettingsChanged(int) ) );
434 kapp->addKipcEventMask( KIPC::SettingsChanged ); 434 kapp->addKipcEventMask( KIPC::SettingsChanged );
435 } 435 }
436*/ 436*/
437 slotSettingsChanged(1); //US do this to initialize the connections 437 slotSettingsChanged(1); //US do this to initialize the connections
438 438
439 439
440 connect(&d->autoSelect, SIGNAL( timeout() ), 440 connect(&d->autoSelect, SIGNAL( timeout() ),
441 this, SLOT( slotAutoSelect() ) ); 441 this, SLOT( slotAutoSelect() ) );
442 connect(&d->dragExpand, SIGNAL( timeout() ), 442 connect(&d->dragExpand, SIGNAL( timeout() ),
443 this, SLOT( slotDragExpand() ) ); 443 this, SLOT( slotDragExpand() ) );
444 444
445 // context menu handling 445 // context menu handling
446 if (d->showContextMenusOnPress) 446 if (d->showContextMenusOnPress)
447 { 447 {
448 connect (this, SIGNAL (rightButtonPressed (QListViewItem*, const QPoint&, int)), 448 connect (this, SIGNAL (rightButtonPressed (QListViewItem*, const QPoint&, int)),
449 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int))); 449 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int)));
450 } 450 }
451 else 451 else
452 { 452 {
453 connect (this, SIGNAL (rightButtonClicked (QListViewItem*, const QPoint&, int)), 453 connect (this, SIGNAL (rightButtonClicked (QListViewItem*, const QPoint&, int)),
454 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int))); 454 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int)));
455 } 455 }
456 456
457 connect (this, SIGNAL (menuShortCutPressed (KListView*, QListViewItem*)), 457 connect (this, SIGNAL (menuShortCutPressed (KListView*, QListViewItem*)),
458 this, SLOT (emitContextMenu (KListView*, QListViewItem*))); 458 this, SLOT (emitContextMenu (KListView*, QListViewItem*)));
459 459
460 460
461 //qDebug("KListView::KListView make alternate color configurable"); 461 //qDebug("KListView::KListView make alternate color configurable");
462 d->alternateBackground = KGlobalSettings::alternateBackgroundColor(); 462 d->alternateBackground = KGlobalSettings::alternateBackgroundColor();
463} 463}
464 464
465 465
466 466
467KListView::~KListView() 467KListView::~KListView()
468{ 468{
469 delete d; 469 delete d;
470} 470}
471 471
472bool KListView::isExecuteArea( const QPoint& point ) 472bool KListView::isExecuteArea( const QPoint& point )
473{ 473{
474 if ( itemAt( point ) ) 474 if ( itemAt( point ) )
475 return isExecuteArea( point.x() ); 475 return isExecuteArea( point.x() );
476 476
477 return false; 477 return false;
478} 478}
479QSize KListView::sizeHint() const
480{
481 //qDebug("KListView::QSize sizeHint() ");
482#ifdef DESKTOP_VERSION
483 QListView::sizeHint();
484#else
485 return QSize ( 40, 40 );
486#endif
479 487
488}
480bool KListView::isExecuteArea( int x ) 489bool KListView::isExecuteArea( int x )
481{ 490{
482 if( allColumnsShowFocus() ) 491 if( allColumnsShowFocus() )
483 return true; 492 return true;
484 else { 493 else {
485 int offset = 0; 494 int offset = 0;
486 int width = columnWidth( 0 ); 495 int width = columnWidth( 0 );
487 int pos = header()->mapToIndex( 0 ); 496 int pos = header()->mapToIndex( 0 );
488 497
489 for ( int index = 0; index < pos; index++ ) 498 for ( int index = 0; index < pos; index++ )
490 offset += columnWidth( header()->mapToSection( index ) ); 499 offset += columnWidth( header()->mapToSection( index ) );
491 500
492 x += contentsX(); // in case of a horizontal scrollbar 501 x += contentsX(); // in case of a horizontal scrollbar
493 return ( x > offset && x < ( offset + width ) ); 502 return ( x > offset && x < ( offset + width ) );
494 } 503 }
495} 504}
496 505
497void KListView::slotOnItem( QListViewItem *item ) 506void KListView::slotOnItem( QListViewItem *item )
498{ 507{
499 QPoint vp = viewport()->mapFromGlobal( QCursor::pos() ); 508 QPoint vp = viewport()->mapFromGlobal( QCursor::pos() );
500 if ( item && isExecuteArea( vp.x() ) && (d->autoSelectDelay > -1) && d->bUseSingle ) { 509 if ( item && isExecuteArea( vp.x() ) && (d->autoSelectDelay > -1) && d->bUseSingle ) {
501 d->autoSelect.start( d->autoSelectDelay, true ); 510 d->autoSelect.start( d->autoSelectDelay, true );
502 d->pCurrentItem = item; 511 d->pCurrentItem = item;
503 } 512 }
504} 513}
505 514
506void KListView::slotOnViewport() 515void KListView::slotOnViewport()
507{ 516{
508 if ( d->bChangeCursorOverItem ) 517 if ( d->bChangeCursorOverItem )
509 viewport()->unsetCursor(); 518 viewport()->unsetCursor();
510 519
511 d->autoSelect.stop(); 520 d->autoSelect.stop();
512 d->pCurrentItem = 0L; 521 d->pCurrentItem = 0L;
513} 522}
514 523
515void KListView::slotSettingsChanged(int category) 524void KListView::slotSettingsChanged(int category)
516{ 525{
517 //qDebug("KListView::slotSettingsChanged has to be verified"); 526 //qDebug("KListView::slotSettingsChanged has to be verified");
518 527
519 528
520 switch (category) 529 switch (category)
521 { 530 {
522 //US I create my private category (=1) to set the settings 531 //US I create my private category (=1) to set the settings
523 case 1: 532 case 1:
524 d->dragDelay = 2; 533 d->dragDelay = 2;
525 //US set explicitly d->bUseSingle = KGlobalSettings::singleClick(); 534 //US set explicitly d->bUseSingle = KGlobalSettings::singleClick();
526 // qDebug("KListView::slotSettingsChanged: single%i", d->bUseSingle); 535 // qDebug("KListView::slotSettingsChanged: single%i", d->bUseSingle);
527 536
528 disconnect(this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)), 537 disconnect(this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)),
529 this, SLOT (slotMouseButtonClicked (int, QListViewItem*, const QPoint &, int))); 538 this, SLOT (slotMouseButtonClicked (int, QListViewItem*, const QPoint &, int)));
530 539
531 if( d->bUseSingle ) 540 if( d->bUseSingle )
532 connect (this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)), 541 connect (this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)),
533 this, SLOT (slotMouseButtonClicked( int, QListViewItem*, const QPoint &, int))); 542 this, SLOT (slotMouseButtonClicked( int, QListViewItem*, const QPoint &, int)));
534 543
535 //US d->bChangeCursorOverItem = KGlobalSettings::changeCursorOverIcon(); 544 //US d->bChangeCursorOverItem = KGlobalSettings::changeCursorOverIcon();
536 //US d->autoSelectDelay = KGlobalSettings::autoSelectDelay(); 545 //US d->autoSelectDelay = KGlobalSettings::autoSelectDelay();
537 546
538 if( !d->bUseSingle || !d->bChangeCursorOverItem ) 547 if( !d->bUseSingle || !d->bChangeCursorOverItem )
539 viewport()->unsetCursor(); 548 viewport()->unsetCursor();
540 549
541 break; 550 break;
542 551
543 /*US 552 /*US
544 case KApplication::SETTINGS_MOUSE: 553 case KApplication::SETTINGS_MOUSE:
545 d->dragDelay = KGlobalSettings::dndEventDelay(); 554 d->dragDelay = KGlobalSettings::dndEventDelay();
546 d->bUseSingle = KGlobalSettings::singleClick(); 555 d->bUseSingle = KGlobalSettings::singleClick();
547 556
548 disconnect(this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)), 557 disconnect(this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)),
549 this, SLOT (slotMouseButtonClicked (int, QListViewItem*, const QPoint &, int))); 558 this, SLOT (slotMouseButtonClicked (int, QListViewItem*, const QPoint &, int)));
550 559
551 if( d->bUseSingle ) 560 if( d->bUseSingle )
552 connect (this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)), 561 connect (this, SIGNAL (mouseButtonClicked (int, QListViewItem*, const QPoint &, int)),
553 this, SLOT (slotMouseButtonClicked( int, QListViewItem*, const QPoint &, int))); 562 this, SLOT (slotMouseButtonClicked( int, QListViewItem*, const QPoint &, int)));
554 563
555 d->bChangeCursorOverItem = KGlobalSettings::changeCursorOverIcon(); 564 d->bChangeCursorOverItem = KGlobalSettings::changeCursorOverIcon();
556 d->autoSelectDelay = KGlobalSettings::autoSelectDelay(); 565 d->autoSelectDelay = KGlobalSettings::autoSelectDelay();
557 566
558 if( !d->bUseSingle || !d->bChangeCursorOverItem ) 567 if( !d->bUseSingle || !d->bChangeCursorOverItem )
559 viewport()->unsetCursor(); 568 viewport()->unsetCursor();
560 569
561 break; 570 break;
562 case KApplication::SETTINGS_POPUPMENU: 571 case KApplication::SETTINGS_POPUPMENU:
563 d->contextMenuKey = KGlobalSettings::contextMenuKey (); 572 d->contextMenuKey = KGlobalSettings::contextMenuKey ();
564 d->showContextMenusOnPress = KGlobalSettings::showContextMenusOnPress (); 573 d->showContextMenusOnPress = KGlobalSettings::showContextMenusOnPress ();
565 574
566 if (d->showContextMenusOnPress) 575 if (d->showContextMenusOnPress)
567 { 576 {
568 disconnect (0L, 0L, this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int))); 577 disconnect (0L, 0L, this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int)));
569 578
570 connect(this, SIGNAL (rightButtonPressed (QListViewItem*, const QPoint&, int)), 579 connect(this, SIGNAL (rightButtonPressed (QListViewItem*, const QPoint&, int)),
571 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int))); 580 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int)));
572 } 581 }
573 else 582 else
574 { 583 {
575 disconnect (0L, 0L, this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int))); 584 disconnect (0L, 0L, this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int)));
576 585
577 connect(this, SIGNAL (rightButtonClicked (QListViewItem*, const QPoint&, int)), 586 connect(this, SIGNAL (rightButtonClicked (QListViewItem*, const QPoint&, int)),
578 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int))); 587 this, SLOT (emitContextMenu (QListViewItem*, const QPoint&, int)));
579 } 588 }
580 break; 589 break;
581 */ 590 */
582 591
583 default: 592 default:
584 break; 593 break;
585 } 594 }
586 595
587} 596}
588 597
589void KListView::slotAutoSelect() 598void KListView::slotAutoSelect()
590{ 599{
591 // check that the item still exists 600 // check that the item still exists
592 if( itemIndex( d->pCurrentItem ) == -1 ) 601 if( itemIndex( d->pCurrentItem ) == -1 )
593 return; 602 return;
594 603
595 if (!isActiveWindow()) 604 if (!isActiveWindow())
596 { 605 {
597 d->autoSelect.stop(); 606 d->autoSelect.stop();
598 return; 607 return;
599 } 608 }
600 609
601 //Give this widget the keyboard focus. 610 //Give this widget the keyboard focus.
602 if( !hasFocus() ) 611 if( !hasFocus() )
603 setFocus(); 612 setFocus();
604 613
605 QListViewItem* previousItem = currentItem(); 614 QListViewItem* previousItem = currentItem();
606 setCurrentItem( d->pCurrentItem ); 615 setCurrentItem( d->pCurrentItem );
607 616
608#if 0 617#if 0
609#ifndef Q_WS_QWS 618#ifndef Q_WS_QWS
610 // FIXME(E): Implement for Qt Embedded 619 // FIXME(E): Implement for Qt Embedded
611 if( d->pCurrentItem ) { 620 if( d->pCurrentItem ) {
612 //Shift pressed? 621 //Shift pressed?
613 if( (keybstate & ShiftMask) ) { 622 if( (keybstate & ShiftMask) ) {
614 bool block = signalsBlocked(); 623 bool block = signalsBlocked();
615 blockSignals( true ); 624 blockSignals( true );
616 625
617 //No Ctrl? Then clear before! 626 //No Ctrl? Then clear before!
618 if( !(keybstate & ControlMask) ) 627 if( !(keybstate & ControlMask) )
619 clearSelection(); 628 clearSelection();
620 629
621 bool select = !d->pCurrentItem->isSelected(); 630 bool select = !d->pCurrentItem->isSelected();
622 bool update = viewport()->isUpdatesEnabled(); 631 bool update = viewport()->isUpdatesEnabled();
623 viewport()->setUpdatesEnabled( false ); 632 viewport()->setUpdatesEnabled( false );
624 633
625 bool down = previousItem->itemPos() < d->pCurrentItem->itemPos(); 634 bool down = previousItem->itemPos() < d->pCurrentItem->itemPos();
626 QListViewItemIterator lit( down ? previousItem : d->pCurrentItem ); 635 QListViewItemIterator lit( down ? previousItem : d->pCurrentItem );
627 for ( ; lit.current(); ++lit ) { 636 for ( ; lit.current(); ++lit ) {
628 if ( down && lit.current() == d->pCurrentItem ) { 637 if ( down && lit.current() == d->pCurrentItem ) {
629 d->pCurrentItem->setSelected( select ); 638 d->pCurrentItem->setSelected( select );
630 break; 639 break;
631 } 640 }
632 if ( !down && lit.current() == previousItem ) { 641 if ( !down && lit.current() == previousItem ) {
633 previousItem->setSelected( select ); 642 previousItem->setSelected( select );
634 break; 643 break;
635 } 644 }
636 lit.current()->setSelected( select ); 645 lit.current()->setSelected( select );
637 } 646 }
638 647
639 blockSignals( block ); 648 blockSignals( block );
640 viewport()->setUpdatesEnabled( update ); 649 viewport()->setUpdatesEnabled( update );
641 triggerUpdate(); 650 triggerUpdate();
642 651
643 emit selectionChanged(); 652 emit selectionChanged();
644 653
645 if( selectionMode() == QListView::Single ) 654 if( selectionMode() == QListView::Single )
646 emit selectionChanged( d->pCurrentItem ); 655 emit selectionChanged( d->pCurrentItem );
647 } 656 }
648 else if( (keybstate & ControlMask) ) 657 else if( (keybstate & ControlMask) )
649 setSelected( d->pCurrentItem, !d->pCurrentItem->isSelected() ); 658 setSelected( d->pCurrentItem, !d->pCurrentItem->isSelected() );
650 else { 659 else {
651 bool block = signalsBlocked(); 660 bool block = signalsBlocked();
652 blockSignals( true ); 661 blockSignals( true );
653 662
654 if( !d->pCurrentItem->isSelected() ) 663 if( !d->pCurrentItem->isSelected() )
655 clearSelection(); 664 clearSelection();
656 665
657 blockSignals( block ); 666 blockSignals( block );
658 667
659 setSelected( d->pCurrentItem, true ); 668 setSelected( d->pCurrentItem, true );
660 } 669 }
661 } 670 }
662 else 671 else
663 kdDebug() << "KListView::slotAutoSelect: Thats not supposed to happen!!!!" << endl; 672 kdDebug() << "KListView::slotAutoSelect: Thats not supposed to happen!!!!" << endl;
664#endif 673#endif
665#endif 674#endif
666} 675}
667 676
668void KListView::slotHeaderChanged() 677void KListView::slotHeaderChanged()
669{ 678{
670 if (d->fullWidth && columns()) 679 if (d->fullWidth && columns())
671 { 680 {
672 int w = 0; 681 int w = 0;
673 for (int i = 0; i < columns() - 1; ++i) w += columnWidth(i); 682 for (int i = 0; i < columns() - 1; ++i) w += columnWidth(i);
674 setColumnWidth( columns() - 1, viewport()->width() - w - 1 ); 683 setColumnWidth( columns() - 1, viewport()->width() - w - 1 );
675 } 684 }
676} 685}
677 686
678void KListView::emitExecute( int buttonstate, QListViewItem *item, const QPoint &pos, int c) 687void KListView::emitExecute( int buttonstate, QListViewItem *item, const QPoint &pos, int c)
679{ 688{
680 // qDebug("KListView::emitExecute buttonstate=%i", buttonstate); 689 // qDebug("KListView::emitExecute buttonstate=%i", buttonstate);
681 if( isExecuteArea( viewport()->mapFromGlobal(pos) ) ) { 690 if( isExecuteArea( viewport()->mapFromGlobal(pos) ) ) {
682 691
683 // Double click mode ? 692 // Double click mode ?
684 if ( !d->bUseSingle ) 693 if ( !d->bUseSingle )
685 { 694 {
686 emit executed( item ); 695 emit executed( item );
687 emit executed( item, pos, c ); 696 emit executed( item, pos, c );
688 } 697 }
689 else 698 else
690 { 699 {
691 //US special implementation for embedded systems 700 //US special implementation for embedded systems
692 d->autoSelect.stop(); 701 d->autoSelect.stop();
693 702
694 //Dont emit executed if in SC mode and Shift or Ctrl are pressed 703 //Dont emit executed if in SC mode and Shift or Ctrl are pressed
695 if( !( (buttonstate==ShiftButton) || (buttonstate==ControlButton) )) { 704 if( !( (buttonstate==ShiftButton) || (buttonstate==ControlButton) )) {
696 // if( !( ((keybstate & ShiftMask) || (keybstate & ControlMask)) ) ) { 705 // if( !( ((keybstate & ShiftMask) || (keybstate & ControlMask)) ) ) {
697 706
698 emit executed( item ); 707 emit executed( item );
699 emit executed( item, pos, c ); 708 emit executed( item, pos, c );
700 } 709 }
701 } 710 }
702 } 711 }
703} 712}
704 713
705void KListView::focusInEvent( QFocusEvent *fe ) 714void KListView::focusInEvent( QFocusEvent *fe )
706{ 715{
707 // kdDebug()<<"KListView::focusInEvent()"<<endl; 716 // kdDebug()<<"KListView::focusInEvent()"<<endl;
708 QListView::focusInEvent( fe ); 717 QListView::focusInEvent( fe );
709 if ((d->selectedBySimpleMove) 718 if ((d->selectedBySimpleMove)
710 && (d->selectionMode == FileManager) 719 && (d->selectionMode == FileManager)
711 && (fe->reason()!=QFocusEvent::Popup) 720 && (fe->reason()!=QFocusEvent::Popup)
712 && (fe->reason()!=QFocusEvent::ActiveWindow) 721 && (fe->reason()!=QFocusEvent::ActiveWindow)
713 && (currentItem()!=0)) 722 && (currentItem()!=0))
714 { 723 {
715 currentItem()->setSelected(true); 724 currentItem()->setSelected(true);
716 currentItem()->repaint(); 725 currentItem()->repaint();
717 emit selectionChanged(); 726 emit selectionChanged();
718 }; 727 };
719} 728}
720 729
721void KListView::focusOutEvent( QFocusEvent *fe ) 730void KListView::focusOutEvent( QFocusEvent *fe )
722{ 731{
723 cleanDropVisualizer(); 732 cleanDropVisualizer();
724 cleanItemHighlighter(); 733 cleanItemHighlighter();
725 734
726 d->autoSelect.stop(); 735 d->autoSelect.stop();
727 736
728 if ((d->selectedBySimpleMove) 737 if ((d->selectedBySimpleMove)
729 && (d->selectionMode == FileManager) 738 && (d->selectionMode == FileManager)
730 && (fe->reason()!=QFocusEvent::Popup) 739 && (fe->reason()!=QFocusEvent::Popup)
731 && (fe->reason()!=QFocusEvent::ActiveWindow) 740 && (fe->reason()!=QFocusEvent::ActiveWindow)
732 && (currentItem()!=0) 741 && (currentItem()!=0)
733/*US && (!d->editor->isVisible()) */ 742/*US && (!d->editor->isVisible()) */
734 ) 743 )
735 { 744 {
736 currentItem()->setSelected(false); 745 currentItem()->setSelected(false);
737 currentItem()->repaint(); 746 currentItem()->repaint();
738 emit selectionChanged(); 747 emit selectionChanged();
739 }; 748 };
740 749
741 QListView::focusOutEvent( fe ); 750 QListView::focusOutEvent( fe );
742} 751}
743 752
744void KListView::leaveEvent( QEvent *e ) 753void KListView::leaveEvent( QEvent *e )
745{ 754{
746 d->autoSelect.stop(); 755 d->autoSelect.stop();
747 756
748 QListView::leaveEvent( e ); 757 QListView::leaveEvent( e );
749} 758}
750 759
751bool KListView::event( QEvent *e ) 760bool KListView::event( QEvent *e )
752{ 761{
753 if (e->type() == QEvent::ApplicationPaletteChange) { 762 if (e->type() == QEvent::ApplicationPaletteChange) {
754 //qDebug("KListView::event make alternate color configurable"); 763 //qDebug("KListView::event make alternate color configurable");
755//US d->alternateBackground=KGlobalSettings::alternateBackgroundColor(); 764//US d->alternateBackground=KGlobalSettings::alternateBackgroundColor();
756 d->alternateBackground = QColor(240, 240, 240); 765 d->alternateBackground = QColor(240, 240, 240);
757 } 766 }
758 767
759 return QListView::event(e); 768 return QListView::event(e);
760} 769}
761 770
762void KListView::contentsMousePressEvent( QMouseEvent *e ) 771void KListView::contentsMousePressEvent( QMouseEvent *e )
763{ 772{
764 //qDebug("KListView::contentsMousePressEvent"); 773 //qDebug("KListView::contentsMousePressEvent");
765 if( (selectionModeExt() == Extended) && (e->state() & ShiftButton) && !(e->state() & ControlButton) ) 774 if( (selectionModeExt() == Extended) && (e->state() & ShiftButton) && !(e->state() & ControlButton) )
766 { 775 {
767 bool block = signalsBlocked(); 776 bool block = signalsBlocked();
768 blockSignals( true ); 777 blockSignals( true );
769 778
770 clearSelection(); 779 clearSelection();
771 780
772 blockSignals( block ); 781 blockSignals( block );
773 } 782 }
774 else if ((selectionModeExt()==FileManager) && (d->selectedBySimpleMove)) 783 else if ((selectionModeExt()==FileManager) && (d->selectedBySimpleMove))
775 { 784 {
776 d->selectedBySimpleMove=false; 785 d->selectedBySimpleMove=false;
777 d->selectedUsingMouse=true; 786 d->selectedUsingMouse=true;
778 if (currentItem()!=0) 787 if (currentItem()!=0)
779 { 788 {
780 currentItem()->setSelected(false); 789 currentItem()->setSelected(false);
781 currentItem()->repaint(); 790 currentItem()->repaint();
782// emit selectionChanged(); 791// emit selectionChanged();
783 }; 792 };
784 }; 793 };
785 794
786 QPoint p( contentsToViewport( e->pos() ) ); 795 QPoint p( contentsToViewport( e->pos() ) );
787 QListViewItem *at = itemAt (p); 796 QListViewItem *at = itemAt (p);
788 797
789 // true if the root decoration of the item "at" was clicked (i.e. the +/- sign) 798 // true if the root decoration of the item "at" was clicked (i.e. the +/- sign)
790 bool rootDecoClicked = at 799 bool rootDecoClicked = at
791 && ( p.x() <= header()->cellPos( header()->mapToActual( 0 ) ) + 800 && ( p.x() <= header()->cellPos( header()->mapToActual( 0 ) ) +
792 treeStepSize() * ( at->depth() + ( rootIsDecorated() ? 1 : 0) ) + itemMargin() ) 801 treeStepSize() * ( at->depth() + ( rootIsDecorated() ? 1 : 0) ) + itemMargin() )
793 && ( p.x() >= header()->cellPos( header()->mapToActual( 0 ) ) ); 802 && ( p.x() >= header()->cellPos( header()->mapToActual( 0 ) ) );
794 803
795 if (e->button() == LeftButton && !rootDecoClicked) 804 if (e->button() == LeftButton && !rootDecoClicked)
796 { 805 {
797 //Start a drag 806 //Start a drag
798 d->startDragPos = e->pos(); 807 d->startDragPos = e->pos();
799 808
800 if (at) 809 if (at)
801 { 810 {
802 d->validDrag = true; 811 d->validDrag = true;
803 d->pressedOnSelected = at->isSelected(); 812 d->pressedOnSelected = at->isSelected();
804 } 813 }
805 } 814 }
806 815
807 QListView::contentsMousePressEvent( e ); 816 QListView::contentsMousePressEvent( e );
808} 817}
809 818
810void KListView::contentsMouseMoveEvent( QMouseEvent *e ) 819void KListView::contentsMouseMoveEvent( QMouseEvent *e )
811{ 820{
812 if (!dragEnabled() || d->startDragPos.isNull() || !d->validDrag) { 821 if (!dragEnabled() || d->startDragPos.isNull() || !d->validDrag) {
813 QListView::contentsMouseMoveEvent (e); 822 QListView::contentsMouseMoveEvent (e);
814 return; 823 return;
815 } 824 }
816 825
817 QPoint vp = contentsToViewport(e->pos()); 826 QPoint vp = contentsToViewport(e->pos());
818 QListViewItem *item = itemAt( vp ); 827 QListViewItem *item = itemAt( vp );
819 828
820 //do we process cursor changes at all? 829 //do we process cursor changes at all?
821 if ( item && d->bChangeCursorOverItem && d->bUseSingle ) 830 if ( item && d->bChangeCursorOverItem && d->bUseSingle )
822 { 831 {
823 //Cursor moved on a new item or in/out the execute area 832 //Cursor moved on a new item or in/out the execute area
824 if( (item != d->pCurrentItem) || 833 if( (item != d->pCurrentItem) ||
825 (isExecuteArea(vp) != d->cursorInExecuteArea) ) 834 (isExecuteArea(vp) != d->cursorInExecuteArea) )
826 { 835 {
827 d->cursorInExecuteArea = isExecuteArea(vp); 836 d->cursorInExecuteArea = isExecuteArea(vp);
828 //qDebug("KListView::contentsMouseMoveEvent drag&drop not supported yet"); 837 //qDebug("KListView::contentsMouseMoveEvent drag&drop not supported yet");
829/*US 838/*US
830 if( d->cursorInExecuteArea ) //cursor moved in execute area 839 if( d->cursorInExecuteArea ) //cursor moved in execute area
831 viewport()->setCursor( KCursor::handCursor() ); 840 viewport()->setCursor( KCursor::handCursor() );
832 else //cursor moved out of execute area 841 else //cursor moved out of execute area
833 viewport()->unsetCursor(); 842 viewport()->unsetCursor();
834*/ 843*/
835 } 844 }
836 } 845 }
837 846
838 bool dragOn = dragEnabled(); 847 bool dragOn = dragEnabled();
839 QPoint newPos = e->pos(); 848 QPoint newPos = e->pos();
840 if (dragOn && d->validDrag && 849 if (dragOn && d->validDrag &&
841 (newPos.x() > d->startDragPos.x()+d->dragDelay || 850 (newPos.x() > d->startDragPos.x()+d->dragDelay ||
842 newPos.x() < d->startDragPos.x()-d->dragDelay || 851 newPos.x() < d->startDragPos.x()-d->dragDelay ||
843 newPos.y() > d->startDragPos.y()+d->dragDelay || 852 newPos.y() > d->startDragPos.y()+d->dragDelay ||
844 newPos.y() < d->startDragPos.y()-d->dragDelay)) 853 newPos.y() < d->startDragPos.y()-d->dragDelay))
845 //(d->startDragPos - e->pos()).manhattanLength() > QApplication::startDragDistance()) 854 //(d->startDragPos - e->pos()).manhattanLength() > QApplication::startDragDistance())
846 { 855 {
847 QListView::contentsMouseReleaseEvent( 0 ); 856 QListView::contentsMouseReleaseEvent( 0 );
848 startDrag(); 857 startDrag();
849 d->startDragPos = QPoint(); 858 d->startDragPos = QPoint();
850 d->validDrag = false; 859 d->validDrag = false;
851 } 860 }
852} 861}
853 862
854void KListView::contentsMouseReleaseEvent( QMouseEvent *e ) 863void KListView::contentsMouseReleaseEvent( QMouseEvent *e )
855{ 864{
856 if (e->button() == LeftButton) 865 if (e->button() == LeftButton)
857 { 866 {
858 // If the row was already selected, maybe we want to start an in-place editing 867 // If the row was already selected, maybe we want to start an in-place editing
859 if ( d->pressedOnSelected && itemsRenameable() ) 868 if ( d->pressedOnSelected && itemsRenameable() )
860 { 869 {
861 QPoint p( contentsToViewport( e->pos() ) ); 870 QPoint p( contentsToViewport( e->pos() ) );
862 QListViewItem *at = itemAt (p); 871 QListViewItem *at = itemAt (p);
863 if ( at ) 872 if ( at )
diff --git a/microkde/kdeui/klistview.h b/microkde/kdeui/klistview.h
index 0058416..9f0d9fd 100644
--- a/microkde/kdeui/klistview.h
+++ b/microkde/kdeui/klistview.h
@@ -1,516 +1,517 @@
1/* This file is part of the KDE libraries 1/* This file is part of the KDE libraries
2 Copyright (C) 2000 Reginald Stadlbauer <reggie@kde.org> 2 Copyright (C) 2000 Reginald Stadlbauer <reggie@kde.org>
3 Copyright (C) 2000 Charles Samuels <charles@kde.org> 3 Copyright (C) 2000 Charles Samuels <charles@kde.org>
4 Copyright (C) 2000 Peter Putzer <putzer@kde.org> 4 Copyright (C) 2000 Peter Putzer <putzer@kde.org>
5 5
6 This library is free software; you can redistribute it and/or 6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Library General Public 7 modify it under the terms of the GNU Library General Public
8 License version 2 as published by the Free Software Foundation. 8 License version 2 as published by the Free Software Foundation.
9 9
10 This library is distributed in the hope that it will be useful, 10 This library is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of 11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 Library General Public License for more details. 13 Library General Public License for more details.
14 14
15 You should have received a copy of the GNU Library General Public License 15 You should have received a copy of the GNU Library General Public License
16 along with this library; see the file COPYING.LIB. If not, write to 16 along with this library; see the file COPYING.LIB. If not, write to
17 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, 17 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 Boston, MA 02111-1307, USA. 18 Boston, MA 02111-1307, USA.
19*/ 19*/
20#ifndef KLISTVIEW_H 20#ifndef KLISTVIEW_H
21#define KLISTVIEW_H 21#define KLISTVIEW_H
22 22
23#include <qlistview.h> 23#include <qlistview.h>
24 24
25#include <qptrlist.h> 25#include <qptrlist.h>
26 26
27//US 27//US
28class QDropEvent; 28class QDropEvent;
29class QDragLeaveEvent; 29class QDragLeaveEvent;
30class QDragMoveEvent; 30class QDragMoveEvent;
31class QDragEnterEvent; 31class QDragEnterEvent;
32 32
33class QDragObject; 33class QDragObject;
34class KConfig; 34class KConfig;
35class KLineEdit; 35class KLineEdit;
36/** 36/**
37 * This Widget extends the functionality of QListView to honor the system 37 * This Widget extends the functionality of QListView to honor the system
38 * wide settings for Single Click/Double Click mode, AutoSelection and 38 * wide settings for Single Click/Double Click mode, AutoSelection and
39 * ChangeCursorOverLink (TM). 39 * ChangeCursorOverLink (TM).
40 * 40 *
41 * There is a new signal executed(). It gets connected to either 41 * There is a new signal executed(). It gets connected to either
42 * @ref QListView::clicked() or @ref QListView::doubleClicked() depending on the KDE 42 * @ref QListView::clicked() or @ref QListView::doubleClicked() depending on the KDE
43 * wide Single Click/Double Click settings. It is strongly recommended that 43 * wide Single Click/Double Click settings. It is strongly recommended that
44 * you use this signal instead of the above mentioned. This way you dont 44 * you use this signal instead of the above mentioned. This way you dont
45 * need to care about the current settings. 45 * need to care about the current settings.
46 * If you want to get informed when the user selects something connect to the 46 * If you want to get informed when the user selects something connect to the
47 * QListView::selectionChanged() signal. 47 * QListView::selectionChanged() signal.
48 * 48 *
49 * Drag-and-Drop is supported with the signal @ref #dropped(), just @ref #setAcceptDrops(true) 49 * Drag-and-Drop is supported with the signal @ref #dropped(), just @ref #setAcceptDrops(true)
50 * and connect it to a suitable slot. 50 * and connect it to a suitable slot.
51 * To see where you are dropping, @ref setDropVisualizer(true). 51 * To see where you are dropping, @ref setDropVisualizer(true).
52 * And also you'll need @ref acceptDrag(QDropEvent*) 52 * And also you'll need @ref acceptDrag(QDropEvent*)
53 * 53 *
54 * KListView is drag-enabled, too: to benefit from that you've got derive from it. 54 * KListView is drag-enabled, too: to benefit from that you've got derive from it.
55 * Reimplement @ref dragObject() and (possibly) @ref startDrag(), 55 * Reimplement @ref dragObject() and (possibly) @ref startDrag(),
56 * and @ref setDragEnabled(true). 56 * and @ref setDragEnabled(true).
57 * 57 *
58 * @version $Id$ 58 * @version $Id$
59 */ 59 */
60class KListView : public QListView 60class KListView : public QListView
61{ 61{
62 Q_OBJECT 62 Q_OBJECT
63 Q_ENUMS( SelectionModeExt ) 63 Q_ENUMS( SelectionModeExt )
64 Q_PROPERTY( bool fullWidth READ fullWidth WRITE setFullWidth ) 64 Q_PROPERTY( bool fullWidth READ fullWidth WRITE setFullWidth )
65 Q_PROPERTY( bool itemsMovable READ itemsMovable WRITE setItemsMovable ) 65 Q_PROPERTY( bool itemsMovable READ itemsMovable WRITE setItemsMovable )
66 Q_PROPERTY( bool itemsRenameable READ itemsRenameable WRITE setItemsRenameable ) 66 Q_PROPERTY( bool itemsRenameable READ itemsRenameable WRITE setItemsRenameable )
67 Q_PROPERTY( bool dragEnabled READ dragEnabled WRITE setDragEnabled ) 67 Q_PROPERTY( bool dragEnabled READ dragEnabled WRITE setDragEnabled )
68 Q_PROPERTY( bool autoOpen READ autoOpen WRITE setAutoOpen ) 68 Q_PROPERTY( bool autoOpen READ autoOpen WRITE setAutoOpen )
69 Q_PROPERTY( bool dropVisualizer READ dropVisualizer WRITE setDropVisualizer ) 69 Q_PROPERTY( bool dropVisualizer READ dropVisualizer WRITE setDropVisualizer )
70//US Q_PROPERTY( int tooltipColumn READ tooltipColumn WRITE setTooltipColumn ) 70//US Q_PROPERTY( int tooltipColumn READ tooltipColumn WRITE setTooltipColumn )
71 Q_PROPERTY( int dropVisualizerWidth READ dropVisualizerWidth WRITE setDropVisualizerWidth ) 71 Q_PROPERTY( int dropVisualizerWidth READ dropVisualizerWidth WRITE setDropVisualizerWidth )
72 Q_PROPERTY( QColor alternateBackground READ alternateBackground WRITE setAlternateBackground ) 72 Q_PROPERTY( QColor alternateBackground READ alternateBackground WRITE setAlternateBackground )
73 73
74 Q_OVERRIDE( SelectionModeExt selectionMode READ selectionModeExt WRITE setSelectionModeExt ) 74 Q_OVERRIDE( SelectionModeExt selectionMode READ selectionModeExt WRITE setSelectionModeExt )
75 75
76public: 76public:
77 /** 77 /**
78 * Possible selection modes. 78 * Possible selection modes.
79 * 79 *
80 * The first four correspond directly to QListView::SelectionMode, while 80 * The first four correspond directly to QListView::SelectionMode, while
81 * the FileManager selection mode is defined as follows: 81 * the FileManager selection mode is defined as follows:
82 * @li home: move to the first 82 * @li home: move to the first
83 * @li end: move to the last 83 * @li end: move to the last
84 * @li PgUp/PgDn: move one page up/down 84 * @li PgUp/PgDn: move one page up/down
85 * @li up/down: move one item up/down 85 * @li up/down: move one item up/down
86 * @li insert: toggle selection of current and move to the next 86 * @li insert: toggle selection of current and move to the next
87 * @li space: toggle selection of the current 87 * @li space: toggle selection of the current
88 * @li CTRL+up: move to the previous item and toggle selection of this one 88 * @li CTRL+up: move to the previous item and toggle selection of this one
89 * @li CTRL+down: toggle selection of the current item and move to the next 89 * @li CTRL+down: toggle selection of the current item and move to the next
90 * @li CTRL+end: toggle selection from (including) the current 90 * @li CTRL+end: toggle selection from (including) the current
91 * item to (including) the last item 91 * item to (including) the last item
92 * @li CTRL+home: toggle selection from (including) the current 92 * @li CTRL+home: toggle selection from (including) the current
93 * item to the (including) the first item 93 * item to the (including) the first item
94 * @li CTRL+PgDn: toggle selection from (including) the current 94 * @li CTRL+PgDn: toggle selection from (including) the current
95 * item to (excluding) the item one page down 95 * item to (excluding) the item one page down
96 * @li CTRL+PgUp: toggle selection from (excluding) the current 96 * @li CTRL+PgUp: toggle selection from (excluding) the current
97 * item to (including) the item one page up 97 * item to (including) the item one page up
98 * 98 *
99 * The combinations work the same with SHIFT instead of CTRL, except 99 * The combinations work the same with SHIFT instead of CTRL, except
100 * that if you start selecting something using SHIFT everything selected 100 * that if you start selecting something using SHIFT everything selected
101 * before will be deselected first. 101 * before will be deselected first.
102 * 102 *
103 * Additionally the current item is always selected automatically when 103 * Additionally the current item is always selected automatically when
104 * navigating using the keyboard, except other items were selected explicitely. 104 * navigating using the keyboard, except other items were selected explicitely.
105 * 105 *
106 * This way e.g. SHIFT+up/PgUp then SHIFT+down/PgDn leaves no item selected 106 * This way e.g. SHIFT+up/PgUp then SHIFT+down/PgDn leaves no item selected
107 */ 107 */
108 enum SelectionModeExt { 108 enum SelectionModeExt {
109 Single = QListView::Single, 109 Single = QListView::Single,
110 Multi = QListView::Multi, 110 Multi = QListView::Multi,
111 Extended = QListView::Extended, 111 Extended = QListView::Extended,
112 NoSelection = QListView::NoSelection, 112 NoSelection = QListView::NoSelection,
113 FileManager 113 FileManager
114 }; 114 };
115 void repaintContents( bool erase = true ) 115 void repaintContents( bool erase = true )
116 { 116 {
117 QScrollView::repaintContents( contentsX(), contentsY(), 117 QScrollView::repaintContents( contentsX(), contentsY(),
118 visibleWidth(), visibleHeight(), erase ); 118 visibleWidth(), visibleHeight(), erase );
119 }; 119 };
120 /** 120 /**
121 * Constructor. 121 * Constructor.
122 * 122 *
123 * The parameters @p parent and @p name are handled by 123 * The parameters @p parent and @p name are handled by
124 * @ref QListView, as usual. 124 * @ref QListView, as usual.
125 */ 125 */
126 KListView (QWidget *parent = 0, const char *name = 0, bool emulateRightMouse = true ); 126 KListView (QWidget *parent = 0, const char *name = 0, bool emulateRightMouse = true );
127 127
128 /** 128 /**
129 * Destructor. 129 * Destructor.
130 */ 130 */
131 virtual ~KListView(); 131 virtual ~KListView();
132 132
133 virtual QSize sizeHint() const;
133 /** 134 /**
134 * Reimplemented for internal reasons. 135 * Reimplemented for internal reasons.
135 * Further reimplementations should call this function or else 136 * Further reimplementations should call this function or else
136 * some features may not work correctly. 137 * some features may not work correctly.
137 * 138 *
138 * The API is unaffected. 139 * The API is unaffected.
139 */ 140 */
140 virtual void setAcceptDrops (bool); 141 virtual void setAcceptDrops (bool);
141 142
142 /** 143 /**
143 * This function determines whether the given coordinates are within the 144 * This function determines whether the given coordinates are within the
144 * execute area. The execute area is the part of a @ref QListViewItem where mouse 145 * execute area. The execute area is the part of a @ref QListViewItem where mouse
145 * clicks or double clicks respectively generate a @ref #executed() signal. 146 * clicks or double clicks respectively generate a @ref #executed() signal.
146 * Depending on @ref QListView::allColumnsShowFocus() this is either the 147 * Depending on @ref QListView::allColumnsShowFocus() this is either the
147 * whole item or only the first column. 148 * whole item or only the first column.
148 * @return true if point is inside execute area of an item, false in all 149 * @return true if point is inside execute area of an item, false in all
149 * other cases including the case that it is over the viewport. 150 * other cases including the case that it is over the viewport.
150 */ 151 */
151 virtual bool isExecuteArea( const QPoint& point ); 152 virtual bool isExecuteArea( const QPoint& point );
152 153
153 /** 154 /**
154 * Same thing, but from an x coordinate only. This only checks if x is in 155 * Same thing, but from an x coordinate only. This only checks if x is in
155 * the first column (if all columns don't show focus), without testing if 156 * the first column (if all columns don't show focus), without testing if
156 * the y coordinate is over an item or not. 157 * the y coordinate is over an item or not.
157 */ 158 */
158 bool isExecuteArea( int x ); 159 bool isExecuteArea( int x );
159 160
160 /** 161 /**
161 * @return a list containing the currently selected items. 162 * @return a list containing the currently selected items.
162 */ 163 */
163 QPtrList<QListViewItem> selectedItems() const; // ### BIC: KDE 4: use an implicitly shared class! (QValueList?) 164 QPtrList<QListViewItem> selectedItems() const; // ### BIC: KDE 4: use an implicitly shared class! (QValueList?)
164 165
165 /** 166 /**
166 * Arbitrarily move @p item to @p parent, positioned immediately after item @p after. 167 * Arbitrarily move @p item to @p parent, positioned immediately after item @p after.
167 */ 168 */
168 void moveItem(QListViewItem *item, QListViewItem *parent, QListViewItem *after); 169 void moveItem(QListViewItem *item, QListViewItem *parent, QListViewItem *after);
169 170
170 /** 171 /**
171 * @return the last item (not child!) of this listview. 172 * @return the last item (not child!) of this listview.
172 * 173 *
173 * @see lastChild() 174 * @see lastChild()
174 */ 175 */
175 QListViewItem *lastItem() const; 176 QListViewItem *lastItem() const;
176 177
177 /** 178 /**
178 * @return the last child of this listview. 179 * @return the last child of this listview.
179 * 180 *
180 * @see lastItem() 181 * @see lastItem()
181 */ 182 */
182 QListViewItem* lastChild () const; 183 QListViewItem* lastChild () const;
183 184
184 /** 185 /**
185 * @return the lineedit used for inline renaming. 186 * @return the lineedit used for inline renaming.
186 * Use that to setup a @ref KCompletion or @ref QValidator for the lineedit 187 * Use that to setup a @ref KCompletion or @ref QValidator for the lineedit
187 * 188 *
188 * @since 3.2 189 * @since 3.2
189 */ 190 */
190 KLineEdit* renameLineEdit() const; 191 KLineEdit* renameLineEdit() const;
191 192
192 /** 193 /**
193 * @returns if it is legal to move items in the list view. True by default. 194 * @returns if it is legal to move items in the list view. True by default.
194 * 195 *
195 * @see #setDragEnabled() 196 * @see #setDragEnabled()
196 * @see #setItemsMovable() 197 * @see #setItemsMovable()
197 */ 198 */
198 bool itemsMovable() const; 199 bool itemsMovable() const;
199 200
200 /** 201 /**
201 * @return whether inplace-renaming has been enabled. False by default. 202 * @return whether inplace-renaming has been enabled. False by default.
202 * 203 *
203 * @see #setItemsRenameable() 204 * @see #setItemsRenameable()
204 */ 205 */
205 bool itemsRenameable() const; 206 bool itemsRenameable() const;
206 207
207 /** 208 /**
208 * @return whether dragging is enabled. False by default. 209 * @return whether dragging is enabled. False by default.
209 * 210 *
210 * @see #setDragEnabled() 211 * @see #setDragEnabled()
211 */ 212 */
212 bool dragEnabled() const; 213 bool dragEnabled() const;
213 214
214 /** 215 /**
215 * @return true if AutoOpen is enabled (not implemented currently). 216 * @return true if AutoOpen is enabled (not implemented currently).
216 * 217 *
217 * @see #setAutoOpen() 218 * @see #setAutoOpen()
218 */ 219 */
219 bool autoOpen() const; 220 bool autoOpen() const;
220 221
221 /** 222 /**
222 * @return true if @p column is renamable. 223 * @return true if @p column is renamable.
223 * 224 *
224 * @see #setRenameable() 225 * @see #setRenameable()
225 */ 226 */
226 bool isRenameable (int column) const; 227 bool isRenameable (int column) const;
227 228
228 /** 229 /**
229 * @return true if drawing of the drop-visualizer has been enabled. True by default. 230 * @return true if drawing of the drop-visualizer has been enabled. True by default.
230 * 231 *
231 * @see #setDropVisualizer() 232 * @see #setDropVisualizer()
232 */ 233 */
233 bool dropVisualizer() const; 234 bool dropVisualizer() const;
234 235
235 /** 236 /**
236 * @return the column for which tooltips are displayed (or -1 if none set). 237 * @return the column for which tooltips are displayed (or -1 if none set).
237 * 238 *
238 * @see #setTooltipColumn() 239 * @see #setTooltipColumn()
239 */ 240 */
240 int tooltipColumn() const; 241 int tooltipColumn() const;
241 242
242 /** 243 /**
243 * For future expansions. 244 * For future expansions.
244 * 245 *
245 * Do not use. 246 * Do not use.
246 * @deprecated 247 * @deprecated
247 */ 248 */
248 bool createChildren() const; 249 bool createChildren() const;
249 250
250 /** 251 /**
251 * @return true if drawing of the drop-highlighter has been enabled. False by default. 252 * @return true if drawing of the drop-highlighter has been enabled. False by default.
252 * 253 *
253 * @see #setDropHighlighter() 254 * @see #setDropHighlighter()
254 */ 255 */
255 bool dropHighlighter() const; 256 bool dropHighlighter() const;
256 257
257 /** 258 /**
258 * The dropVisualizerWidth defaults to 4. 259 * The dropVisualizerWidth defaults to 4.
259 * 260 *
260 * @see #setDropVisualizerWidth() 261 * @see #setDropVisualizerWidth()
261 * @return the current width of the drop-visualizer. 262 * @return the current width of the drop-visualizer.
262 */ 263 */
263 int dropVisualizerWidth () const; 264 int dropVisualizerWidth () const;
264 265
265 /** 266 /**
266 * @return the "extended" selection mode of this listview. 267 * @return the "extended" selection mode of this listview.
267 * 268 *
268 * @see SelectionModeExt 269 * @see SelectionModeExt
269 * @see setSelectionModeExt 270 * @see setSelectionModeExt
270 */ 271 */
271 SelectionModeExt selectionModeExt () const; 272 SelectionModeExt selectionModeExt () const;
272 273
273 /** 274 /**
274 * Returns the index of @p item within the item tree or -1 if 275 * Returns the index of @p item within the item tree or -1 if
275 * @p item doesn't exist in this list view. This function takes 276 * @p item doesn't exist in this list view. This function takes
276 * all items into account not only the visible ones. 277 * all items into account not only the visible ones.
277 */ 278 */
278 int itemIndex( const QListViewItem *item ) const; 279 int itemIndex( const QListViewItem *item ) const;
279 280
280 /** 281 /**
281 * Returns the item of @p index within the item tree or 0 if 282 * Returns the item of @p index within the item tree or 0 if
282 * @p index doesn't exist in this list view. This function takes 283 * @p index doesn't exist in this list view. This function takes
283 * all items into account not only the visible ones. 284 * all items into account not only the visible ones.
284 */ 285 */
285 QListViewItem* itemAtIndex(int index); 286 QListViewItem* itemAtIndex(int index);
286 287
287 /** 288 /**
288 * @deprecated 289 * @deprecated
289 * @see #setFullWidth() 290 * @see #setFullWidth()
290 */ 291 */
291 void setFullWidth(); 292 void setFullWidth();
292 293
293 /** 294 /**
294 * Let the last column fit exactly all the available width. 295 * Let the last column fit exactly all the available width.
295 * 296 *
296 * @see #fullWidth() 297 * @see #fullWidth()
297 */ 298 */
298 void setFullWidth(bool fullWidth); 299 void setFullWidth(bool fullWidth);
299 300
300 /** 301 /**
301 * Returns whether the last column is set to fit the available width. 302 * Returns whether the last column is set to fit the available width.
302 * 303 *
303 * @see #setFullWidth() 304 * @see #setFullWidth()
304 */ 305 */
305 bool fullWidth() const; 306 bool fullWidth() const;
306 307
307 /** 308 /**
308 * Reimplemented for full width support 309 * Reimplemented for full width support
309 * 310 *
310 * @see #removeColumn() 311 * @see #removeColumn()
311 */ 312 */
312 virtual int addColumn(const QString& label, int width = -1); 313 virtual int addColumn(const QString& label, int width = -1);
313 /** 314 /**
314 * Reimplemented for full width support 315 * Reimplemented for full width support
315 */ 316 */
316 virtual int addColumn(const QIconSet& iconset, const QString& label, int width = -1); 317 virtual int addColumn(const QIconSet& iconset, const QString& label, int width = -1);
317 /** 318 /**
318 * Reimplemented for full width support 319 * Reimplemented for full width support
319 * 320 *
320 * @see #addColumn() 321 * @see #addColumn()
321 */ 322 */
322 virtual void removeColumn(int index); 323 virtual void removeColumn(int index);
323 324
324 /** 325 /**
325 * sets the alternate background background color. 326 * sets the alternate background background color.
326 * This only has an effect if the items are KListViewItems 327 * This only has an effect if the items are KListViewItems
327 * 328 *
328 * @param c the color to use for every other item. Set to an invalid 329 * @param c the color to use for every other item. Set to an invalid
329 * colour to disable alternate colours. 330 * colour to disable alternate colours.
330 * 331 *
331 * @see #alternateBackground() 332 * @see #alternateBackground()
332 **/ 333 **/
333 void setAlternateBackground(const QColor &c); 334 void setAlternateBackground(const QColor &c);
334 /** 335 /**
335 * @return the alternate background color 336 * @return the alternate background color
336 * 337 *
337 * @see #setAlternateBackground() 338 * @see #setAlternateBackground()
338 */ 339 */
339 const QColor &alternateBackground() const; 340 const QColor &alternateBackground() const;
340 341
341 /** 342 /**
342 * Saves the list view's layout (column widtsh, column order, sort column) 343 * Saves the list view's layout (column widtsh, column order, sort column)
343 * to a KConfig group 344 * to a KConfig group
344 * 345 *
345 * @param config the @ref KConfig object to write to 346 * @param config the @ref KConfig object to write to
346 * @param group the config group to use 347 * @param group the config group to use
347 */ 348 */
348 void saveLayout(KConfig *config, const QString &group) const; 349 void saveLayout(KConfig *config, const QString &group) const;
349 /** 350 /**
350 * Reads the list view's layout from a KConfig group as stored with 351 * Reads the list view's layout from a KConfig group as stored with
351 * @ref #saveLayout 352 * @ref #saveLayout
352 * 353 *
353 * @param config the @ref KConfig object to read from 354 * @param config the @ref KConfig object to read from
354 * @param group the config group to use 355 * @param group the config group to use
355 */ 356 */
356 void restoreLayout(KConfig *config, const QString &group); 357 void restoreLayout(KConfig *config, const QString &group);
357 /** 358 /**
358 * Reimplemented to remember the current sort column and order. 359 * Reimplemented to remember the current sort column and order.
359 * @param column is the column to be sorted, or -1 to sort in order of 360 * @param column is the column to be sorted, or -1 to sort in order of
360 * insertion 361 * insertion
361 * @param whether to sort ascending (or descending) 362 * @param whether to sort ascending (or descending)
362 */ 363 */
363 virtual void setSorting(int column, bool ascending = true); 364 virtual void setSorting(int column, bool ascending = true);
364 365
365 /** 366 /**
366 * @return the currently sorted column, or -1 if none is sorted 367 * @return the currently sorted column, or -1 if none is sorted
367 */ 368 */
368 int columnSorted(void) const; 369 int columnSorted(void) const;
369 370
370 /** 371 /**
371 * @return whether the current sort is ascending (or descending) 372 * @return whether the current sort is ascending (or descending)
372 */ 373 */
373 bool ascendingSort(void) const; 374 bool ascendingSort(void) const;
374 375
375 //US we do not have a "global KDE" variable to setup singleClick functionality 376 //US we do not have a "global KDE" variable to setup singleClick functionality
376 void setSingleClick(bool s); 377 void setSingleClick(bool s);
377 378
378 379
379signals: 380signals:
380 381
381 /** 382 /**
382 * This signal is emitted whenever the user executes an listview item. 383 * This signal is emitted whenever the user executes an listview item.
383 * That means depending on the KDE wide Single Click/Double Click 384 * That means depending on the KDE wide Single Click/Double Click
384 * setting the user clicked or double clicked on that item. 385 * setting the user clicked or double clicked on that item.
385 * @param item is the pointer to the executed listview item. 386 * @param item is the pointer to the executed listview item.
386 * 387 *
387 * Note that you may not delete any @ref QListViewItem objects in slots 388 * Note that you may not delete any @ref QListViewItem objects in slots
388 * connected to this signal. 389 * connected to this signal.
389 */ 390 */
390 void executed( QListViewItem *item ); 391 void executed( QListViewItem *item );
391 392
392 /** 393 /**
393 * This signal is emitted whenever the user executes an listview item. 394 * This signal is emitted whenever the user executes an listview item.
394 * That means depending on the KDE wide Single Click/Double Click 395 * That means depending on the KDE wide Single Click/Double Click
395 * setting the user clicked or double clicked on that item. 396 * setting the user clicked or double clicked on that item.
396 * @param item is the pointer to the executed listview item. 397 * @param item is the pointer to the executed listview item.
397 * @param pos is the position where the user has clicked 398 * @param pos is the position where the user has clicked
398 * @param c is the column into which the user clicked. 399 * @param c is the column into which the user clicked.
399 * 400 *
400 * Note that you may not delete any @ref QListViewItem objects in slots 401 * Note that you may not delete any @ref QListViewItem objects in slots
401 * connected to this signal. 402 * connected to this signal.
402 */ 403 */
403 void executed( QListViewItem *item, const QPoint &pos, int c ); 404 void executed( QListViewItem *item, const QPoint &pos, int c );
404 405
405 /** 406 /**
406 * This signal gets emitted whenever the user double clicks into the 407 * This signal gets emitted whenever the user double clicks into the
407 * listview. 408 * listview.
408 * @param item is the pointer to the clicked listview item. 409 * @param item is the pointer to the clicked listview item.
409 * @param pos is the position where the user has clicked, and 410 * @param pos is the position where the user has clicked, and
410 * @param c is the column into which the user clicked. 411 * @param c is the column into which the user clicked.
411 * 412 *
412 * Note that you may not delete any @ref QListViewItem objects in slots 413 * Note that you may not delete any @ref QListViewItem objects in slots
413 * connected to this signal. 414 * connected to this signal.
414 * 415 *
415 * This signal is more or less here for the sake of completeness. 416 * This signal is more or less here for the sake of completeness.
416 * You should normally not need to use this. In most cases its better 417 * You should normally not need to use this. In most cases its better
417 * to use @ref #executed() instead. 418 * to use @ref #executed() instead.
418 */ 419 */
419 void doubleClicked( QListViewItem *item, const QPoint &pos, int c ); 420 void doubleClicked( QListViewItem *item, const QPoint &pos, int c );
420 void contextRequest( QListViewItem *item, const QPoint &pos, int c ); 421 void contextRequest( QListViewItem *item, const QPoint &pos, int c );
421 422
422 /** 423 /**
423 * This signal gets emitted whenever something acceptable is 424 * This signal gets emitted whenever something acceptable is
424 * dropped onto the listview. 425 * dropped onto the listview.
425 * 426 *
426 * @param e is the drop event itself (it has already been accepted) 427 * @param e is the drop event itself (it has already been accepted)
427 * @param after is the item after which the drop occured (or 0L, if 428 * @param after is the item after which the drop occured (or 0L, if
428 * the drop was above all items) 429 * the drop was above all items)
429 * 430 *
430 * @see #acceptDrop() 431 * @see #acceptDrop()
431 */ 432 */
432 void dropped (QDropEvent * e, QListViewItem *after); 433 void dropped (QDropEvent * e, QListViewItem *after);
433 434
434 /** 435 /**
435 * This signal gets emitted whenever something acceptable is 436 * This signal gets emitted whenever something acceptable is
436 * dropped onto the listview. 437 * dropped onto the listview.
437 * 438 *
438 * This is an overloaded version of the above (provided to simplify 439 * This is an overloaded version of the above (provided to simplify
439 * processing drops outside of the class). 440 * processing drops outside of the class).
440 * 441 *
441 * @param list is the listview 442 * @param list is the listview
442 * @param e is the drop event itself (it has already been accepted) 443 * @param e is the drop event itself (it has already been accepted)
443 * @param after is the item after which the drop occured (or 0L, if 444 * @param after is the item after which the drop occured (or 0L, if
444 * the drop was above all items 445 * the drop was above all items
445 */ 446 */
446 void dropped (KListView* list, QDropEvent* e, QListViewItem* after); 447 void dropped (KListView* list, QDropEvent* e, QListViewItem* after);
447 448
448 /** 449 /**
449 * This signal gets emitted whenever something acceptable is 450 * This signal gets emitted whenever something acceptable is
450 * dropped onto the listview. 451 * dropped onto the listview.
451 * 452 *
452 * This function also provides a parent, in the event that your listview 453 * This function also provides a parent, in the event that your listview
453 * is a tree 454 * is a tree
454 * @param list is the listview 455 * @param list is the listview
455 * @param e is the drop event itself (it has already been accepted) 456 * @param e is the drop event itself (it has already been accepted)
456 * @param parent the item that is to be the parent of the new item 457 * @param parent the item that is to be the parent of the new item
457 * @param after is the item after which the drop occured (or 0L, if 458 * @param after is the item after which the drop occured (or 0L, if
458 * the drop was above all items 459 * the drop was above all items
459 */ 460 */
460 void dropped (KListView* list, QDropEvent* e, QListViewItem* parent, QListViewItem* after); 461 void dropped (KListView* list, QDropEvent* e, QListViewItem* parent, QListViewItem* after);
461 462
462 /** 463 /**
463 * This signal gets emitted whenever something acceptable is 464 * This signal gets emitted whenever something acceptable is
464 * dropped onto the listview. 465 * dropped onto the listview.
465 * 466 *
466 * This function also provides a parent, in the event that your listview 467 * This function also provides a parent, in the event that your listview
467 * is a tree 468 * is a tree
468 * @param e is the drop event itself (it has already been accepted) 469 * @param e is the drop event itself (it has already been accepted)
469 * @param parent the item that is to be the parent of the new item 470 * @param parent the item that is to be the parent of the new item
470 * @param after is the item after which the drop occured (or 0L, if 471 * @param after is the item after which the drop occured (or 0L, if
471 * the drop was above all items 472 * the drop was above all items
472 */ 473 */
473 void dropped (QDropEvent* e, QListViewItem* parent, QListViewItem* after); 474 void dropped (QDropEvent* e, QListViewItem* parent, QListViewItem* after);
474 475
475 /** 476 /**
476 * This signal is emitted when ever the user moves an item in the list via 477 * This signal is emitted when ever the user moves an item in the list via
477 * DnD. 478 * DnD.
478 * If more than one item is moved at the same time, this signal is only emitted 479 * If more than one item is moved at the same time, this signal is only emitted
479 * once. 480 * once.
480 */ 481 */
481 void moved(); 482 void moved();
482 483
483 /** 484 /**
484 * Connect to this signal if you want to do some preprocessing before 485 * Connect to this signal if you want to do some preprocessing before
485 * a move is made, for example, to disable sorting 486 * a move is made, for example, to disable sorting
486 * 487 *
487 * This is sent only once per each groups of moves. That is, for each 488 * This is sent only once per each groups of moves. That is, for each
488 * drop that is a move this will be emitted once, before KListView calls 489 * drop that is a move this will be emitted once, before KListView calls
489 * @see moveItem() 490 * @see moveItem()
490 */ 491 */
491 void aboutToMove(); 492 void aboutToMove();
492 493
493 /** 494 /**
494 * This signal is emitted when ever the user moves an item in the list via 495 * This signal is emitted when ever the user moves an item in the list via
495 * DnD. 496 * DnD.
496 * If more than one item is moved at the same time, @p afterFirst and 497 * If more than one item is moved at the same time, @p afterFirst and
497 * @p afterNow will reflect what was true before the move. 498 * @p afterNow will reflect what was true before the move.
498 * This differs from @ref moved(), so be careful. All the items will have been 499 * This differs from @ref moved(), so be careful. All the items will have been
499 * moved before @ref moved() is emitted, which is not true in this method. // FIXME 500 * moved before @ref moved() is emitted, which is not true in this method. // FIXME
500 * @param item the item that was moved 501 * @param item the item that was moved
501 * @param afterFirst the item that parameter item was in before the move, in the list 502 * @param afterFirst the item that parameter item was in before the move, in the list
502 * @param afterNow the item it's currently after. 503 * @param afterNow the item it's currently after.
503 */ 504 */
504 void moved (QListViewItem *item, QListViewItem *afterFirst, QListViewItem *afterNow); 505 void moved (QListViewItem *item, QListViewItem *afterFirst, QListViewItem *afterNow);
505 506
506 507
507 /** 508 /**
508 * This signal is emitted after all the items have been moved. It reports info for 509 * This signal is emitted after all the items have been moved. It reports info for
509 * each and every item moved, in order. The first element in @p items associates 510 * each and every item moved, in order. The first element in @p items associates
510 * with the first of afterFirst and afterNow. 511 * with the first of afterFirst and afterNow.
511 */ 512 */
512 void moved(QPtrList<QListViewItem> &items, QPtrList<QListViewItem> &afterFirst, QPtrList<QListViewItem> &afterNow); 513 void moved(QPtrList<QListViewItem> &items, QPtrList<QListViewItem> &afterFirst, QPtrList<QListViewItem> &afterNow);
513 514
514 /** 515 /**
515 * This signal gets emitted when an item is renamed via in-place renaming. 516 * This signal gets emitted when an item is renamed via in-place renaming.
516 * 517 *