mirror of
https://invent.kde.org/system/dolphin
synced 2024-09-19 16:31:21 +00:00
Implement contextMenu handling in dolphin part (for konqueror)
svn path=/trunk/KDE/kdebase/apps/; revision=705873
This commit is contained in:
parent
9c7ccd477a
commit
246c18a93c
|
@ -72,11 +72,15 @@ DolphinPart::DolphinPart(QWidget* parentWidget, QObject* parent, const QStringLi
|
||||||
this, SLOT(slotErrorMessage(QString)));
|
this, SLOT(slotErrorMessage(QString)));
|
||||||
connect(m_view, SIGNAL(itemTriggered(KFileItem)),
|
connect(m_view, SIGNAL(itemTriggered(KFileItem)),
|
||||||
this, SLOT(slotItemTriggered(KFileItem)));
|
this, SLOT(slotItemTriggered(KFileItem)));
|
||||||
// TODO connect to urlsDropped
|
connect(m_view, SIGNAL(requestContextMenu(KFileItem, const KUrl&)),
|
||||||
// TOOD connect to requestContextMenu
|
this, SLOT(slotOpenContextMenu(KFileItem, const KUrl&)));
|
||||||
connect(m_view, SIGNAL(selectionChanged(QList<KFileItem>)), m_extension, SIGNAL(selectionInfo(QList<KFileItem>)));
|
connect(m_view, SIGNAL(selectionChanged(QList<KFileItem>)),
|
||||||
|
m_extension, SIGNAL(selectionInfo(QList<KFileItem>)));
|
||||||
|
|
||||||
connect(m_view, SIGNAL(requestItemInfo(KFileItem)), this, SLOT(slotRequestItemInfo(KFileItem)));
|
connect(m_view, SIGNAL(requestItemInfo(KFileItem)),
|
||||||
|
this, SLOT(slotRequestItemInfo(KFileItem)));
|
||||||
|
|
||||||
|
// TODO connect to urlsDropped
|
||||||
|
|
||||||
// TODO there was a "always open a new window" (when clicking on a directory) setting in konqueror
|
// TODO there was a "always open a new window" (when clicking on a directory) setting in konqueror
|
||||||
// (sort of spacial navigation)
|
// (sort of spacial navigation)
|
||||||
|
@ -101,8 +105,8 @@ KAboutData* DolphinPart::createAboutData()
|
||||||
bool DolphinPart::openUrl(const KUrl& url)
|
bool DolphinPart::openUrl(const KUrl& url)
|
||||||
{
|
{
|
||||||
const QString prettyUrl = url.pathOrUrl();
|
const QString prettyUrl = url.pathOrUrl();
|
||||||
setWindowCaption(prettyUrl);
|
emit setWindowCaption(prettyUrl);
|
||||||
m_extension->setLocationBarUrl(prettyUrl);
|
emit m_extension->setLocationBarUrl(prettyUrl);
|
||||||
m_view->setUrl(url);
|
m_view->setUrl(url);
|
||||||
if (arguments().reload())
|
if (arguments().reload())
|
||||||
m_view->reload();
|
m_view->reload();
|
||||||
|
@ -141,4 +145,19 @@ void DolphinPart::slotItemTriggered(const KFileItem& item)
|
||||||
emit m_extension->openUrlRequest(item.url());
|
emit m_extension->openUrlRequest(item.url());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void DolphinPart::slotOpenContextMenu(const KFileItem& item, const KUrl&)
|
||||||
|
{
|
||||||
|
// TODO KonqKfmIconView had if ( !rootItem->isWritable() )
|
||||||
|
// popupFlags |= KParts::BrowserExtension::NoDeletion;
|
||||||
|
|
||||||
|
// and when clicking on the viewport:
|
||||||
|
// KParts::BrowserExtension::PopupFlags popupFlags = KParts::BrowserExtension::ShowNavigationItems | KParts::BrowserExtension::ShowUp;
|
||||||
|
|
||||||
|
|
||||||
|
KFileItem* itemCopy = new KFileItem(item); // ugly
|
||||||
|
KFileItemList items; items.append(itemCopy);
|
||||||
|
emit m_extension->popupMenu( 0, QCursor::pos(), items );
|
||||||
|
delete itemCopy;
|
||||||
|
}
|
||||||
|
|
||||||
#include "dolphinpart.moc"
|
#include "dolphinpart.moc"
|
||||||
|
|
|
@ -51,8 +51,22 @@ private Q_SLOTS:
|
||||||
void slotCanceled(const KUrl& url);
|
void slotCanceled(const KUrl& url);
|
||||||
void slotInfoMessage(const QString& msg);
|
void slotInfoMessage(const QString& msg);
|
||||||
void slotErrorMessage(const QString& msg);
|
void slotErrorMessage(const QString& msg);
|
||||||
|
/**
|
||||||
|
* Shows the information for the item \a item inside the statusbar. If the
|
||||||
|
* item is null, the default statusbar information is shown.
|
||||||
|
*/
|
||||||
void slotRequestItemInfo(const KFileItem& item);
|
void slotRequestItemInfo(const KFileItem& item);
|
||||||
|
/**
|
||||||
|
* Handles clicking on an item
|
||||||
|
*/
|
||||||
void slotItemTriggered(const KFileItem& item);
|
void slotItemTriggered(const KFileItem& item);
|
||||||
|
/**
|
||||||
|
* Opens the context menu on the current mouse position.
|
||||||
|
* @item File item context. If item is 0, the context menu
|
||||||
|
* should be applied to \a url.
|
||||||
|
* @url URL which contains \a item.
|
||||||
|
*/
|
||||||
|
void slotOpenContextMenu(const KFileItem& item, const KUrl& url);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DolphinView* m_view;
|
DolphinView* m_view;
|
||||||
|
|
|
@ -177,7 +177,7 @@ private slots:
|
||||||
void changeNameFilter(const QString& nameFilter);
|
void changeNameFilter(const QString& nameFilter);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Opens the context menu on the current mouse postition.
|
* Opens the context menu on the current mouse position.
|
||||||
* @item File item context. If item is 0, the context menu
|
* @item File item context. If item is 0, the context menu
|
||||||
* should be applied to \a url.
|
* should be applied to \a url.
|
||||||
* @url URL which contains \a item.
|
* @url URL which contains \a item.
|
||||||
|
|
Loading…
Reference in a new issue