-void NickView::customEvent(QEvent *event) {
- // THIS IS A REPLACEMENT FOR expandAll()
- /* WARNING: do not call expandAll()!
- * it fucks up big time in combination with sorting and changing the rootIndex
- * the following sequence of commands leads to unexpected behavior when inserting new items
- * setSortingEnabled(true);
- * setModel();
- * expandAll();
- * setRootIndex();
- */
- if(event->type() != QEvent::User)
- return;
-
- QModelIndex topLevelIdx;
- for(int i = 0; i < model()->rowCount(rootIndex()); i++) {
- topLevelIdx = model()->index(i, 0, rootIndex());
- if(isExpanded(topLevelIdx))
- continue;
- else {
- expand(topLevelIdx);
- if(i < model()->rowCount(rootIndex()) - 1)
- QCoreApplication::postEvent(this, new ExpandAllEvent);
- break;
- }
- }
- event->accept();
+
+void NickView::unanimatedExpandAll()
+{
+ // since of Qt Version 4.8.0 the default expandAll will not properly work if
+ // animations are enabled. Therefore we perform an unanimated expand when a
+ // model is set or a toplevel node is inserted.
+ bool wasAnimated = isAnimated();
+ setAnimated(false);
+ expandAll();
+ setAnimated(wasAnimated);