Mode mode) :
QWidget(parent),
m_active(true),
- m_blockContentsMovedSignal(false),
+ m_loadingDirectory(false),
m_initializeColumnView(false),
m_mode(mode),
m_topLayout(0),
connect(clipboard, SIGNAL(dataChanged()),
this, SLOT(updateCutItems()));
- connect(m_dirLister, SIGNAL(completed()),
- this, SLOT(restoreContentsPos()));
connect(m_dirLister, SIGNAL(completed()),
this, SLOT(updateCutItems()));
connect(m_dirLister, SIGNAL(newItems(const KFileItemList&)),
// to go back to the root URL of the column view automatically.
// Otherwise there it would not be possible to turn off the column view
// without focusing the first column.
- // TODO: reactivate again after DolphinView/DolphinViewController split works
- //setUrl(m_dirLister->url());
- //m_controller->setUrl(m_dirLister->url());
+ setUrl(m_dirLister->url());
+ m_controller->setUrl(m_dirLister->url());
}
ViewProperties props(url());
selectAll(QItemSelectionModel::Toggle);
}
-int DolphinView::contentsX() const
+bool DolphinView::hasSelection() const
{
- return itemView()->horizontalScrollBar()->value();
+ return itemView()->selectionModel()->hasSelection();
}
-int DolphinView::contentsY() const
+void DolphinView::clearSelection()
{
- return itemView()->verticalScrollBar()->value();
+ itemView()->selectionModel()->clear();
+}
+
+KFileItemList DolphinView::selectedItems() const
+{
+ const QAbstractItemView* view = itemView();
+
+ // Our view has a selection, we will map them back to the DirModel
+ // and then fill the KFileItemList.
+ Q_ASSERT((view != 0) && (view->selectionModel() != 0));
+
+ const QItemSelection selection = m_proxyModel->mapSelectionToSource(view->selectionModel()->selection());
+ KFileItemList itemList;
+
+ const QModelIndexList indexList = selection.indexes();
+ QModelIndexList::const_iterator end = indexList.end();
+ for (QModelIndexList::const_iterator it = indexList.begin(); it != end; ++it) {
+ Q_ASSERT((*it).isValid());
+
+ KFileItem* item = m_dirModel->itemForIndex(*it);
+ if (item != 0) {
+ itemList.append(item);
+ }
+ }
+
+ return itemList;
+}
+
+KUrl::List DolphinView::selectedUrls() const
+{
+ KUrl::List urls;
+
+ const KFileItemList list = selectedItems();
+ KFileItemList::const_iterator it = list.begin();
+ const KFileItemList::const_iterator end = list.end();
+ while (it != end) {
+ KFileItem* item = *it;
+ urls.append(item->url());
+ ++it;
+ }
+
+ return urls;
+}
+
+KFileItem* DolphinView::fileItem(const QModelIndex index) const
+{
+ const QModelIndex dirModelIndex = m_proxyModel->mapToSource(index);
+ return m_dirModel->itemForIndex(dirModelIndex);
+}
+
+void DolphinView::setContentsPosition(int x, int y)
+{
+ QAbstractItemView* view = itemView();
+ view->horizontalScrollBar()->setValue(x);
+ view->verticalScrollBar()->setValue(y);
+
+ m_loadingDirectory = false;
+}
+
+QPoint DolphinView::contentsPosition() const
+{
+ const int x = itemView()->horizontalScrollBar()->value();
+ const int y = itemView()->verticalScrollBar()->value();
+ return QPoint(x, y);
}
void DolphinView::zoomIn()
return m_fileItemDelegate->additionalInformation();
}
-bool DolphinView::hasSelection() const
-{
- return itemView()->selectionModel()->hasSelection();
-}
-
-void DolphinView::clearSelection()
-{
- itemView()->selectionModel()->clear();
-}
-
-KFileItemList DolphinView::selectedItems() const
-{
- const QAbstractItemView* view = itemView();
-
- // Our view has a selection, we will map them back to the DirModel
- // and then fill the KFileItemList.
- Q_ASSERT((view != 0) && (view->selectionModel() != 0));
-
- const QItemSelection selection = m_proxyModel->mapSelectionToSource(view->selectionModel()->selection());
- KFileItemList itemList;
-
- const QModelIndexList indexList = selection.indexes();
- QModelIndexList::const_iterator end = indexList.end();
- for (QModelIndexList::const_iterator it = indexList.begin(); it != end; ++it) {
- Q_ASSERT((*it).isValid());
-
- KFileItem* item = m_dirModel->itemForIndex(*it);
- if (item != 0) {
- itemList.append(item);
- }
- }
-
- return itemList;
-}
-
-KUrl::List DolphinView::selectedUrls() const
-{
- KUrl::List urls;
-
- const KFileItemList list = selectedItems();
- KFileItemList::const_iterator it = list.begin();
- const KFileItemList::const_iterator end = list.end();
- while (it != end) {
- KFileItem* item = *it;
- urls.append(item->url());
- ++it;
- }
-
- return urls;
-}
-
-KFileItem* DolphinView::fileItem(const QModelIndex index) const
-{
- const QModelIndex dirModelIndex = m_proxyModel->mapToSource(index);
- return m_dirModel->itemForIndex(dirModelIndex);
-}
-
void DolphinView::reload()
{
setUrl(url());
}
}
-void DolphinView::restoreContentsPos()
-{
- m_blockContentsMovedSignal = false;
- if (!url().isEmpty()) {
- QAbstractItemView* view = itemView();
- // TODO #1: view->setCurrentItem(m_urlNavigator->currentFileName());
- // TODO #2: temporary deactivated due to DolphinView/DolphinViewController split
- //QPoint pos = m_urlNavigator->savedPosition();
- QPoint pos(0, 0);
- view->horizontalScrollBar()->setValue(pos.x());
- view->verticalScrollBar()->setValue(pos.y());
- }
-}
-
void DolphinView::emitSelectionChangedSignal()
{
emit selectionChanged(DolphinView::selectedItems());
}
m_cutItemsCache.clear();
- m_blockContentsMovedSignal = true;
+ m_loadingDirectory = true;
+
m_dirLister->stop();
bool openDir = true;
void DolphinView::emitContentsMoved()
{
- if (!m_blockContentsMovedSignal) {
- emit contentsMoved(contentsX(), contentsY());
+ // only emit the contents moved signal if:
+ // - no directory loading is ongoing (this would reset the contents position
+ // always to (0, 0))
+ // - if the Column View is active: the column view does an automatic
+ // positioning during the loading operation, which must be remembered
+ if (!m_loadingDirectory || isColumnViewActive()) {
+ const QPoint pos(contentsPosition());
+ emit contentsMoved(pos.x(), pos.y());
}
}