aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src-qt5/core/lumina-desktop/desktop-plugins/applauncher/AppLauncherPlugin.h31
1 files changed, 31 insertions, 0 deletions
diff --git a/src-qt5/core/lumina-desktop/desktop-plugins/applauncher/AppLauncherPlugin.h b/src-qt5/core/lumina-desktop/desktop-plugins/applauncher/AppLauncherPlugin.h
index c8e3a475..833a2a48 100644
--- a/src-qt5/core/lumina-desktop/desktop-plugins/applauncher/AppLauncherPlugin.h
+++ b/src-qt5/core/lumina-desktop/desktop-plugins/applauncher/AppLauncherPlugin.h
@@ -18,6 +18,8 @@
#include <QTimer>
#include <QMenu>
#include <QCursor>
+#include <QDrag>
+#include <QMimeData>
#include "../LDPlugin.h"
@@ -38,6 +40,7 @@ private:
QInputDialog *inputDLG;
QString iconID;
int icosize;
+ QPoint dragstartpos;
private slots:
void loadButton();
@@ -74,5 +77,33 @@ protected:
QEvent::Type tmp = ev->type();
if(tmp == QEvent::StyleChange || tmp==QEvent::ThemeChange || tmp==QEvent::LanguageChange || tmp==QEvent::LocaleChange){ loadButton(); }
}
+
+ void mousePressEvent(QMouseEvent *ev){
+ if(ev->button()==Qt::LeftButton){
+ dragstartpos = ev->pos();
+ }
+ }
+
+ void mouseMoveEvent(QMouseEvent *ev){
+ if( (ev->buttons() & Qt::LeftButton) ){
+ if((ev->pos() - dragstartpos).manhattanLength() > (this->width()/4) ){
+ //Start the drag event for this file
+ QDrag *drag = new QDrag(this);
+ QMimeData *md = new QMimeData;
+ md->setUrls( QList<QUrl>() << QUrl::fromLocalFile(button->whatsThis()) );
+ drag->setMimeData(md);
+ //Now perform the drag and react appropriately
+ Qt::DropAction dropAction = drag->exec(Qt::CopyAction | Qt::MoveAction);
+ if(dropAction == Qt::MoveAction){
+ // File Moved, remove it from here
+ //qDebug() << "File Moved:" << button->whatsThis();
+ //DO NOT DELETE FILES - return code often is wrong (browser drops for instance)
+ }
+ }
+ }else{
+ LDPlugin::mouseMoveEvent(ev);
+ }
+
+ }
};
#endif
bgstack15