diff --git a/popupapplet.cpp b/popupapplet.cpp index dbc65dbe3..305b54bf0 100644 --- a/popupapplet.cpp +++ b/popupapplet.cpp @@ -308,8 +308,8 @@ void PopupAppletPrivate::popupConstraintsEvent(Plasma::Constraints constraints) q->resize(prefSize); emit q->appletTransformedItself(); } - //Applet on popup } else { + //Applet on popup if (icon && lay) { lay->addItem(icon); } @@ -330,56 +330,57 @@ void PopupAppletPrivate::popupConstraintsEvent(Plasma::Constraints constraints) delete proxy.data(); } - if (!dialogPtr) { - //save the aspect ratio mode in case we drag'n drop in the Desktop later - savedAspectRatio = q->aspectRatioMode(); + //save the aspect ratio mode in case we drag'n drop in the Desktop later + savedAspectRatio = q->aspectRatioMode(); - if (icon) { - icon->show(); - q->setAspectRatioMode(Plasma::ConstrainedSquare); - } - - Dialog *dialog = new Dialog(); - dialog->d->appletPtr = q; - dialogPtr = dialog; - - if (icon) { - dialog->setAspectRatioMode(savedAspectRatio); - } - - //no longer use Qt::Popup since that seems to cause a lot of problem when you drag - //stuff out of your Dialog. Monitor WindowDeactivate events so we can - //emulate the same kind of behavior as Qt::Popup (close when you click somewhere - //else. - - if (gWidget) { - Corona *corona = qobject_cast(gWidget->scene()); - - if (corona) { - corona->addOffscreenWidget(gWidget); - } - - dialog->setGraphicsWidget(gWidget); - //gWidget->resize(gWidget->preferredSize()); - dialog->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint | (gWidget->windowFlags() & Qt::X11BypassWindowManagerHint)); - } else if (qWidget) { - QVBoxLayout *l_layout = new QVBoxLayout(dialog); - l_layout->setSpacing(0); - l_layout->setMargin(0); - l_layout->addWidget(qWidget); - dialog->adjustSize(); - dialog->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint | (qWidget->windowFlags() & Qt::X11BypassWindowManagerHint)); - } else { - dialog->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint); - } - - restoreDialogSize(); - KWindowSystem::setState(dialog->winId(), NET::SkipTaskbar | NET::SkipPager); - dialog->installEventFilter(q); - - QObject::connect(dialog, SIGNAL(dialogResized()), q, SLOT(dialogSizeChanged())); - QObject::connect(dialog, SIGNAL(dialogVisible(bool)), q, SLOT(dialogStatusChanged(bool))); + if (icon) { + icon->show(); + q->setAspectRatioMode(Plasma::ConstrainedSquare); } + + Dialog *dialog = new Dialog(); + dialog->d->appletPtr = q; + dialogPtr = dialog; + + if (icon) { + dialog->setAspectRatioMode(savedAspectRatio); + } + + //no longer use Qt::Popup since that seems to cause a lot of problem when you drag + //stuff out of your Dialog (extenders). Monitor WindowDeactivate events so we can + //emulate the same kind of behavior as Qt::Popup (close when you click somewhere + //else. + + if (gWidget) { + Corona *corona = qobject_cast(gWidget->scene()); + if (!corona) { + corona = qobject_cast(q->scene()); + } + + if (corona) { + corona->addOffscreenWidget(gWidget); + } + + gWidget->show(); + dialog->setGraphicsWidget(gWidget); + dialog->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint | (gWidget->windowFlags() & Qt::X11BypassWindowManagerHint)); + } else if (qWidget) { + QVBoxLayout *l_layout = new QVBoxLayout(dialog); + l_layout->setSpacing(0); + l_layout->setMargin(0); + l_layout->addWidget(qWidget); + dialog->adjustSize(); + dialog->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint | (qWidget->windowFlags() & Qt::X11BypassWindowManagerHint)); + } else { + dialog->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowStaysOnTopHint); + } + + restoreDialogSize(); + KWindowSystem::setState(dialog->winId(), NET::SkipTaskbar | NET::SkipPager); + dialog->installEventFilter(q); + + QObject::connect(dialog, SIGNAL(dialogResized()), q, SLOT(dialogSizeChanged())); + QObject::connect(dialog, SIGNAL(dialogVisible(bool)), q, SLOT(dialogStatusChanged(bool))); } } @@ -591,7 +592,6 @@ PopupAppletPrivate::PopupAppletPrivate(PopupApplet *applet) : q(applet), icon(0), widget(0), - graphicsWidget(0), popupPlacement(Plasma::FloatingPopup), popupAlignment(Qt::AlignLeft), savedAspectRatio(Plasma::InvalidAspectRatioMode), diff --git a/private/popupapplet_p.h b/private/popupapplet_p.h index 2f8a02dab..01eea6ccf 100644 --- a/private/popupapplet_p.h +++ b/private/popupapplet_p.h @@ -58,7 +58,7 @@ public: QWeakPointer dialogPtr; QWeakPointer proxy; QWidget *widget; - QGraphicsWidget *graphicsWidget; + QWeakPointer graphicsWidget; Plasma::PopupPlacement popupPlacement; Qt::AlignmentFlag popupAlignment; Plasma::AspectRatioMode savedAspectRatio;