When switching from e. g. the icons view to the details view, additional information properties like 'Size' and 'Date' are added as default (showing a details-view without details does not make sense as default setting...). This fix assures that the additional information properties are removed again when switching back to the icons view. Only if the user modified the additional information properties by a GUI-interaction (e. g. by adding a 'Type'), this information is persistet also when switching back to the icon-view.

BUG: 151891

svn path=/trunk/KDE/kdebase/apps/; revision=733313
This commit is contained in:
Peter Penz 2007-11-06 07:16:23 +00:00
parent 96f134eecc
commit f1d1a18a71
4 changed files with 76 additions and 32 deletions

View file

@ -43,6 +43,7 @@
DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* controller) : DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* controller) :
QTreeView(parent), QTreeView(parent),
m_controller(controller), m_controller(controller),
m_clearAdditionalInfo(false),
m_dragging(false), m_dragging(false),
m_showElasticBand(false), m_showElasticBand(false),
m_elasticBandOrigin(), m_elasticBandOrigin(),
@ -349,6 +350,20 @@ void DolphinDetailsView::resizeEvent(QResizeEvent* event)
} }
} }
void DolphinDetailsView::closeEvent(QCloseEvent* event)
{
if (m_clearAdditionalInfo) {
disconnect(m_controller->dolphinView(), SIGNAL(additionalInfoChanged(const KFileItemDelegate::InformationList&)),
this, SLOT(updateColumnVisibility()));
KFileItemDelegate::InformationList info;
info.append(KFileItemDelegate::NoInformation);
m_controller->indicateAdditionalInfoChange(info);
m_clearAdditionalInfo = true;
}
QTreeView::closeEvent(event);
}
void DolphinDetailsView::setSortIndicatorSection(DolphinView::Sorting sorting) void DolphinDetailsView::setSortIndicatorSection(DolphinView::Sorting sorting)
{ {
QHeaderView* headerView = header(); QHeaderView* headerView = header();
@ -457,17 +472,7 @@ void DolphinDetailsView::configureColumns(const QPoint& pos)
const int columnIndex = activatedAction->data().toInt(); const int columnIndex = activatedAction->data().toInt();
KFileItemDelegate::InformationList list = m_controller->dolphinView()->additionalInfo(); KFileItemDelegate::InformationList list = m_controller->dolphinView()->additionalInfo();
KFileItemDelegate::Information info = KFileItemDelegate::NoInformation; const KFileItemDelegate::Information info = infoForColumn(columnIndex);
switch (columnIndex) {
case DolphinModel::Size: info = KFileItemDelegate::Size; break;
case DolphinModel::ModifiedTime: info = KFileItemDelegate::ModificationTime; break;
case DolphinModel::Permissions: info = KFileItemDelegate::Permissions; break;
case DolphinModel::Owner: info = KFileItemDelegate::Owner; break;
case DolphinModel::Group: info = KFileItemDelegate::OwnerAndGroup; break;
case DolphinModel::Type: info = KFileItemDelegate::FriendlyMimeType; break;
default: break;
}
if (show) { if (show) {
Q_ASSERT(!list.contains(info)); Q_ASSERT(!list.contains(info));
list.append(info); list.append(info);
@ -485,7 +490,10 @@ void DolphinDetailsView::configureColumns(const QPoint& pos)
void DolphinDetailsView::updateColumnVisibility() void DolphinDetailsView::updateColumnVisibility()
{ {
KFileItemDelegate::InformationList list = m_controller->dolphinView()->additionalInfo(); KFileItemDelegate::InformationList list = m_controller->dolphinView()->additionalInfo();
if (list.isEmpty() || list.contains(KFileItemDelegate::NoInformation)) { const bool useDefaultColumns = !isVisible() &&
(list.isEmpty() ||
list.contains(KFileItemDelegate::NoInformation));
if (useDefaultColumns) {
// Using the details view without any additional information (-> additional column) // Using the details view without any additional information (-> additional column)
// makes no sense and leads to a usability problem as no viewport area is available // makes no sense and leads to a usability problem as no viewport area is available
// anymore. Hence as fallback provide at least a size and date column. // anymore. Hence as fallback provide at least a size and date column.
@ -493,14 +501,17 @@ void DolphinDetailsView::updateColumnVisibility()
list.append(KFileItemDelegate::Size); list.append(KFileItemDelegate::Size);
list.append(KFileItemDelegate::ModificationTime); list.append(KFileItemDelegate::ModificationTime);
m_controller->indicateAdditionalInfoChange(list); m_controller->indicateAdditionalInfoChange(list);
m_clearAdditionalInfo = true;
} }
setColumnHidden(DolphinModel::Size, !list.contains(KFileItemDelegate::Size)); for (int i = DolphinModel::Size; i <= DolphinModel::Type; ++i) {
setColumnHidden(DolphinModel::ModifiedTime, !list.contains(KFileItemDelegate::ModificationTime)); const KFileItemDelegate::Information info = infoForColumn(i);
setColumnHidden(DolphinModel::Permissions, !list.contains(KFileItemDelegate::Permissions)); const bool hide = !list.contains(info);
setColumnHidden(DolphinModel::Owner, !list.contains(KFileItemDelegate::Owner)); if (isColumnHidden(i) != hide) {
setColumnHidden(DolphinModel::Group, !list.contains(KFileItemDelegate::OwnerAndGroup)); setColumnHidden(i, hide);
setColumnHidden(DolphinModel::Type, !list.contains(KFileItemDelegate::FriendlyMimeType)); m_clearAdditionalInfo = false;
}
}
} }
bool DolphinDetailsView::isZoomInPossible() const bool DolphinDetailsView::isZoomInPossible() const
@ -553,4 +564,21 @@ KFileItem DolphinDetailsView::itemForIndex(const QModelIndex& index) const
return dirModel->itemForIndex(dirIndex); return dirModel->itemForIndex(dirIndex);
} }
KFileItemDelegate::Information DolphinDetailsView::infoForColumn(int columnIndex) const
{
KFileItemDelegate::Information info = KFileItemDelegate::NoInformation;
switch (columnIndex) {
case DolphinModel::Size: info = KFileItemDelegate::Size; break;
case DolphinModel::ModifiedTime: info = KFileItemDelegate::ModificationTime; break;
case DolphinModel::Permissions: info = KFileItemDelegate::Permissions; break;
case DolphinModel::Owner: info = KFileItemDelegate::Owner; break;
case DolphinModel::Group: info = KFileItemDelegate::OwnerAndGroup; break;
case DolphinModel::Type: info = KFileItemDelegate::FriendlyMimeType; break;
default: break;
}
return info;
}
#include "dolphindetailsview.moc" #include "dolphindetailsview.moc"

View file

@ -58,6 +58,7 @@ protected:
virtual void paintEvent(QPaintEvent* event); virtual void paintEvent(QPaintEvent* event);
virtual void keyPressEvent(QKeyEvent* event); virtual void keyPressEvent(QKeyEvent* event);
virtual void resizeEvent(QResizeEvent* event); virtual void resizeEvent(QResizeEvent* event);
virtual void closeEvent(QCloseEvent* event);
private slots: private slots:
/** /**
@ -135,10 +136,14 @@ private:
KFileItem itemForIndex(const QModelIndex& index) const; KFileItem itemForIndex(const QModelIndex& index) const;
KFileItemDelegate::Information infoForColumn(int columnIndex) const;
private: private:
DolphinController* m_controller; DolphinController* m_controller;
QStyleOptionViewItem m_viewOptions; QStyleOptionViewItem m_viewOptions;
bool m_clearAdditionalInfo;
bool m_dragging; // TODO: remove this property when the issue #160611 is solved in Qt 4.4 bool m_dragging; // TODO: remove this property when the issue #160611 is solved in Qt 4.4
QRect m_dropRect; // TODO: remove this property when the issue #160611 is solved in Qt 4.4 QRect m_dropRect; // TODO: remove this property when the issue #160611 is solved in Qt 4.4

View file

@ -194,6 +194,11 @@ void DolphinView::setMode(Mode mode)
m_controller->setUrl(root); m_controller->setUrl(root);
} }
deleteView();
// It is important to read the view properties _after_ deleting the view,
// as e. g. the detail view might adjust the additional information properties
// after getting closed:
const KUrl viewPropsUrl = viewPropertiesUrl(); const KUrl viewPropsUrl = viewPropertiesUrl();
ViewProperties props(viewPropsUrl); ViewProperties props(viewPropsUrl);
props.setViewMode(m_mode); props.setViewMode(m_mode);
@ -770,6 +775,7 @@ void DolphinView::updateAdditionalInfo(const KFileItemDelegate::InformationList&
{ {
ViewProperties props(viewPropertiesUrl()); ViewProperties props(viewPropertiesUrl());
props.setAdditionalInfo(info); props.setAdditionalInfo(info);
props.save();
m_fileItemDelegate->setShowInformation(info); m_fileItemDelegate->setShowInformation(info);
@ -826,24 +832,12 @@ void DolphinView::clearHoverInformation()
void DolphinView::createView() void DolphinView::createView()
{ {
// delete current view deleteView();
QAbstractItemView* view = itemView();
if (view != 0) {
m_topLayout->removeWidget(view);
view->close();
view->deleteLater();
view = 0;
m_iconsView = 0;
m_detailsView = 0;
m_columnView = 0;
m_fileItemDelegate = 0;
}
Q_ASSERT(m_iconsView == 0); Q_ASSERT(m_iconsView == 0);
Q_ASSERT(m_detailsView == 0); Q_ASSERT(m_detailsView == 0);
Q_ASSERT(m_columnView == 0); Q_ASSERT(m_columnView == 0);
// ... and recreate it representing the current mode QAbstractItemView* view = 0;
switch (m_mode) { switch (m_mode) {
case IconsView: { case IconsView: {
m_iconsView = new DolphinIconsView(this, m_controller); m_iconsView = new DolphinIconsView(this, m_controller);
@ -881,6 +875,21 @@ void DolphinView::createView()
this, SLOT(emitContentsMoved())); this, SLOT(emitContentsMoved()));
} }
void DolphinView::deleteView()
{
QAbstractItemView* view = itemView();
if (view != 0) {
m_topLayout->removeWidget(view);
view->close();
view->deleteLater();
view = 0;
m_iconsView = 0;
m_detailsView = 0;
m_columnView = 0;
m_fileItemDelegate = 0;
}
}
QAbstractItemView* DolphinView::itemView() const QAbstractItemView* DolphinView::itemView() const
{ {
if (m_detailsView != 0) { if (m_detailsView != 0) {

View file

@ -566,6 +566,8 @@ private:
*/ */
void createView(); void createView();
void deleteView();
/** /**
* Returns a pointer to the currently used item view, which is either * Returns a pointer to the currently used item view, which is either
* a ListView or a TreeView. * a ListView or a TreeView.