mirror of
https://invent.kde.org/system/dolphin
synced 2024-11-05 18:47:12 +00:00
Internal cleanups to assure that the asynchronous request for the folder-information works reliable when switching between directories.
svn path=/trunk/KDE/kdebase/apps/; revision=1183537
This commit is contained in:
parent
431da0482c
commit
6751f6a52a
2 changed files with 44 additions and 36 deletions
|
@ -18,12 +18,13 @@
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "informationpanel.h"
|
#include "informationpanel.h"
|
||||||
|
|
||||||
|
#include "informationpanelcontent.h"
|
||||||
|
#include <kio/job.h>
|
||||||
#include <kdirnotify.h>
|
#include <kdirnotify.h>
|
||||||
|
#include <QApplication>
|
||||||
#include <QShowEvent>
|
#include <QShowEvent>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
#include "informationpanelcontent.h"
|
|
||||||
|
|
||||||
#include <kio/job.h>
|
|
||||||
|
|
||||||
InformationPanel::InformationPanel(QWidget* parent) :
|
InformationPanel::InformationPanel(QWidget* parent) :
|
||||||
Panel(parent),
|
Panel(parent),
|
||||||
|
@ -89,34 +90,46 @@ void InformationPanel::requestDelayedItemInfo(const KFileItem& item)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
cancelRequest();
|
if (QApplication::mouseButtons() & Qt::LeftButton) {
|
||||||
|
// Ignore the request of an item information when a rubberband
|
||||||
|
// selection is ongoing.
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
m_fileItem = KFileItem();
|
|
||||||
if (item.isNull()) {
|
if (item.isNull()) {
|
||||||
// The cursor is above the viewport. If files are selected,
|
// The cursor is above the viewport. If files are selected,
|
||||||
// show information regarding the selection.
|
// show information regarding the selection.
|
||||||
if (m_selection.size() > 0) {
|
if (m_selection.size() > 0) {
|
||||||
|
cancelRequest();
|
||||||
m_infoTimer->start();
|
m_infoTimer->start();
|
||||||
}
|
}
|
||||||
} else {
|
} else if (item.url().isValid() && !isEqualToShownUrl(item.url())) {
|
||||||
const KUrl url = item.url();
|
// The cursor is above an item that is not shown currently
|
||||||
if (url.isValid() && !isEqualToShownUrl(url)) {
|
cancelRequest();
|
||||||
m_urlCandidate = item.url();
|
|
||||||
m_fileItem = item;
|
m_urlCandidate = item.url();
|
||||||
m_infoTimer->start();
|
m_fileItem = item;
|
||||||
}
|
m_infoTimer->start();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InformationPanel::urlChanged()
|
bool InformationPanel::urlChanged()
|
||||||
{
|
{
|
||||||
if (!url().isValid() || isEqualToShownUrl(url())) {
|
if (!url().isValid()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_shownUrl = url();
|
if (!isVisible()) {
|
||||||
if (isVisible()) {
|
return true;
|
||||||
cancelRequest();
|
}
|
||||||
|
|
||||||
|
cancelRequest();
|
||||||
|
m_selection.clear();
|
||||||
|
|
||||||
|
if (!isEqualToShownUrl(url())) {
|
||||||
|
m_shownUrl = url();
|
||||||
|
m_fileItem = KFileItem();
|
||||||
|
|
||||||
// Update the content with a delay. This gives
|
// Update the content with a delay. This gives
|
||||||
// the directory lister the chance to show the content
|
// the directory lister the chance to show the content
|
||||||
// before expensive operations are done to show
|
// before expensive operations are done to show
|
||||||
|
@ -137,6 +150,8 @@ void InformationPanel::showEvent(QShowEvent* event)
|
||||||
// Information Panel
|
// Information Panel
|
||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
m_shownUrl = url();
|
||||||
showItemInfo();
|
showItemInfo();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -164,10 +179,11 @@ void InformationPanel::showItemInfo()
|
||||||
|
|
||||||
cancelRequest();
|
cancelRequest();
|
||||||
|
|
||||||
if (showMultipleSelectionInfo()) {
|
if (m_fileItem.isNull() && (m_selection.count() > 1)) {
|
||||||
|
// The information for a selection of items should be shown
|
||||||
m_content->showItems(m_selection);
|
m_content->showItems(m_selection);
|
||||||
m_shownUrl = KUrl();
|
|
||||||
} else {
|
} else {
|
||||||
|
// The information for exactly one item should be shown
|
||||||
KFileItem item;
|
KFileItem item;
|
||||||
if (!m_fileItem.isNull()) {
|
if (!m_fileItem.isNull()) {
|
||||||
item = m_fileItem;
|
item = m_fileItem;
|
||||||
|
@ -177,9 +193,9 @@ void InformationPanel::showItemInfo()
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item.isNull()) {
|
if (item.isNull()) {
|
||||||
// no item is hovered and no selection has been done: provide
|
// No item is hovered and no selection has been done: provide
|
||||||
// an item for the directory represented by m_shownUrl
|
// an item for the currently shown directory.
|
||||||
m_folderStatJob = KIO::stat(m_shownUrl, KIO::HideProgressInfo);
|
m_folderStatJob = KIO::stat(url(), KIO::HideProgressInfo);
|
||||||
connect(m_folderStatJob, SIGNAL(result(KJob*)),
|
connect(m_folderStatJob, SIGNAL(result(KJob*)),
|
||||||
this, SLOT(slotFolderStatFinished(KJob*)));
|
this, SLOT(slotFolderStatFinished(KJob*)));
|
||||||
} else {
|
} else {
|
||||||
|
@ -198,6 +214,7 @@ void InformationPanel::slotFolderStatFinished(KJob* job)
|
||||||
void InformationPanel::slotInfoTimeout()
|
void InformationPanel::slotInfoTimeout()
|
||||||
{
|
{
|
||||||
m_shownUrl = m_urlCandidate;
|
m_shownUrl = m_urlCandidate;
|
||||||
|
m_urlCandidate.clear();
|
||||||
showItemInfo();
|
showItemInfo();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -288,12 +305,13 @@ void InformationPanel::cancelRequest()
|
||||||
{
|
{
|
||||||
delete m_folderStatJob;
|
delete m_folderStatJob;
|
||||||
m_folderStatJob = 0;
|
m_folderStatJob = 0;
|
||||||
m_infoTimer->stop();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool InformationPanel::showMultipleSelectionInfo() const
|
m_infoTimer->stop();
|
||||||
{
|
m_urlChangedTimer->stop();
|
||||||
return m_fileItem.isNull() && (m_selection.count() > 1);
|
m_resetUrlTimer->stop();
|
||||||
|
|
||||||
|
m_invalidUrlCandidate.clear();
|
||||||
|
m_urlCandidate.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool InformationPanel::isEqualToShownUrl(const KUrl& url) const
|
bool InformationPanel::isEqualToShownUrl(const KUrl& url) const
|
||||||
|
|
|
@ -112,16 +112,6 @@ private:
|
||||||
*/
|
*/
|
||||||
void showMetaInfo();
|
void showMetaInfo();
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns true, if the meta information should be shown for
|
|
||||||
* the multiple selected items that are stored in
|
|
||||||
* m_selection. If true is returned, it is assured that
|
|
||||||
* m_selection.count() > 1. If false is returned, the meta
|
|
||||||
* information should be shown for the file
|
|
||||||
* InformationPanel::fileUrl();
|
|
||||||
*/
|
|
||||||
bool showMultipleSelectionInfo() const;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true, if \a url is equal to the shown URL m_shownUrl.
|
* Returns true, if \a url is equal to the shown URL m_shownUrl.
|
||||||
*/
|
*/
|
||||||
|
|
Loading…
Reference in a new issue