Updated LibraryWindow::reloadAfterCopyMove for only re-fetching/updating the affected folders by a copy/move action

This commit is contained in:
Luis Ángel San Martín 2014-10-15 16:30:51 +02:00
parent 46e4cfceb9
commit ebf2ee72b2
5 changed files with 94 additions and 74 deletions

View File

@ -1,70 +1,19 @@
/****************************************************************************
**
** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (qt-info@nokia.com)
**
** This file is part of the examples of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:BSD$
** You may use this file under the terms of the BSD license as follows:
**
** "Redistribution and use in source and binary forms, with or without
** modification, are permitted provided that the following conditions are
** met:
** * Redistributions of source code must retain the above copyright
** notice, this list of conditions and the following disclaimer.
** * Redistributions in binary form must reproduce the above copyright
** notice, this list of conditions and the following disclaimer in
** the documentation and/or other materials provided with the
** distribution.
** * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
** the names of its contributors may be used to endorse or promote
** products derived from this software without specific prior written
** permission.
**
** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
** $QT_END_LICENSE$
**
****************************************************************************/
/*
treeitem.cpp
A container for items of data supplied by the simple tree model.
*/
#include <QStringList> #include <QStringList>
#include "treeitem.h" #include "treeitem.h"
#include "qnaturalsorting.h" #include "qnaturalsorting.h"
//! [0]
TreeItem::TreeItem(const QList<QVariant> &data, TreeItem *parent) TreeItem::TreeItem(const QList<QVariant> &data, TreeItem *parent)
{ {
parentItem = parent; parentItem = parent;
itemData = data; itemData = data;
} }
//! [0]
//! [1]
TreeItem::~TreeItem() TreeItem::~TreeItem()
{ {
qDeleteAll(childItems); qDeleteAll(childItems);
} }
//! [1]
//! [2]
void TreeItem::appendChild(TreeItem *item) void TreeItem::appendChild(TreeItem *item)
{ {
item->parentItem = this; item->parentItem = this;
@ -74,7 +23,7 @@ void TreeItem::appendChild(TreeItem *item)
else else
{ {
TreeItem * last = childItems.back(); TreeItem * last = childItems.back();
QString nameLast = last->data(1).toString(); //TODO usar info name si está disponible, sino el nombre del fichero..... QString nameLast = last->data(1).toString(); //TODO usar info name si est<EFBFBD> disponible, sino el nombre del fichero.....
QString nameCurrent = item->data(1).toString(); QString nameCurrent = item->data(1).toString();
QList<TreeItem *>::iterator i; QList<TreeItem *>::iterator i;
i = childItems.end(); i = childItems.end();
@ -84,7 +33,7 @@ void TreeItem::appendChild(TreeItem *item)
i--; i--;
nameLast = (*i)->data(1).toString(); nameLast = (*i)->data(1).toString();
} }
if(!naturalSortLessThanCI(nameCurrent,nameLast)) //si se ha encontrado un elemento menor que current, se inserta justo después if(!naturalSortLessThanCI(nameCurrent,nameLast)) //si se ha encontrado un elemento menor que current, se inserta justo despu<EFBFBD>s
childItems.insert(++i,item); childItems.insert(++i,item);
else else
childItems.insert(i,item); childItems.insert(i,item);
@ -93,49 +42,48 @@ void TreeItem::appendChild(TreeItem *item)
//childItems.append(item); //childItems.append(item);
} }
//! [2]
//! [3]
TreeItem *TreeItem::child(int row) TreeItem *TreeItem::child(int row)
{ {
return childItems.value(row); return childItems.value(row);
} }
//! [3]
//! [4]
int TreeItem::childCount() const int TreeItem::childCount() const
{ {
return childItems.count(); return childItems.count();
} }
//! [4]
//! [5]
int TreeItem::columnCount() const int TreeItem::columnCount() const
{ {
return itemData.count(); return itemData.count();
} }
//! [5]
//! [6]
QVariant TreeItem::data(int column) const QVariant TreeItem::data(int column) const
{ {
return itemData.value(column); return itemData.value(column);
} }
//! [6]
void TreeItem::setData(int column, const QVariant & value) void TreeItem::setData(int column, const QVariant & value)
{ {
itemData[column] = value; itemData[column] = value;
} }
//! [7] void TreeItem::clearChildren()
{
qDeleteAll(childItems);
childItems.clear();
}
QList<TreeItem *> TreeItem::children()
{
return childItems;
}
TreeItem *TreeItem::parent() TreeItem *TreeItem::parent()
{ {
return parentItem; return parentItem;
} }
//! [7]
//! [8]
int TreeItem::row() const int TreeItem::row() const
{ {
if (parentItem) if (parentItem)
@ -143,8 +91,6 @@ int TreeItem::row() const
return 0; return 0;
} }
//! [8]
QList<QVariant> TreeItem::getData() const QList<QVariant> TreeItem::getData() const
{ {

View File

@ -45,7 +45,6 @@
#include <QVariant> #include <QVariant>
#include <QModelIndex> #include <QModelIndex>
//! [0]
class TreeItem class TreeItem
{ {
public: public:
@ -66,6 +65,8 @@ public:
QList<QString> comicNames; QList<QString> comicNames;
TreeItem * originalItem; TreeItem * originalItem;
void setData(int column, const QVariant &value); void setData(int column, const QVariant &value);
void clearChildren();
QList<TreeItem*> children();
private: private:
QList<TreeItem*> childItems; QList<TreeItem*> childItems;
QList<QVariant> itemData; QList<QVariant> itemData;

View File

@ -311,11 +311,33 @@ void TreeModel::setupModelData(QSqlQuery &sqlquery, TreeItem *parent)
item->id = record.value("id").toULongLong(); item->id = record.value("id").toULongLong();
//la inserci<63>n de hijos se hace de forma ordenada //la inserci<63>n de hijos se hace de forma ordenada
TreeItem * parent = items.value(record.value("parentId").toULongLong()); TreeItem * parent = items.value(record.value("parentId").toULongLong());
if(parent !=0) //TODO if parent==0 the parent of item was removed from the DB and delete on cascade didn't work, ERROR. //if(parent !=0) //TODO if parent==0 the parent of item was removed from the DB and delete on cascade didn't work, ERROR.
parent->appendChild(item); parent->appendChild(item);
//se a<>ade el item al map, de forma que se pueda encontrar como padre en siguientes iteraciones //se a<>ade el item al map, de forma que se pueda encontrar como padre en siguientes iteraciones
items.insert(item->id,item); items.insert(item->id,item);
} }
}
void TreeModel::updateFolderModelData(QSqlQuery &sqlquery, TreeItem *parent)
{
while (sqlquery.next()) {
QList<QVariant> data;
QSqlRecord record = sqlquery.record();
data << record.value("name").toString();
data << record.value("path").toString();
data << record.value("finished").toBool();
data << record.value("completed").toBool();
TreeItem * item = new TreeItem(data);
item->id = record.value("id").toULongLong();
//la inserci<63>n de hijos se hace de forma ordenada
TreeItem * parent = items.value(record.value("parentId").toULongLong());
if(parent !=0) //TODO if parent==0 the parent of item was removed from the DB and delete on cascade didn't work, ERROR.
parent->appendChild(item);
//se a<>ade el item al map, de forma que se pueda encontrar como padre en siguientes iteraciones
items.insert(item->id,item);
}
} }
void TreeModel::setupFilteredModelData() void TreeModel::setupFilteredModelData()
@ -545,7 +567,57 @@ QStringList TreeModel::getSubfoldersNames(const QModelIndex &mi)
return result; return result;
} }
void TreeModel::fetchMore(const QModelIndex &parent) void TreeModel::fetchMoreFromDB(const QModelIndex &parent)
{ {
TreeItem * item;
if(parent.isValid())
item = static_cast<TreeItem*>(parent.internalPointer());
else
item = rootItem;
//Remove all children
beginRemoveRows(parent, 0, item->childCount());
item->clearChildren();
endRemoveRows();
QSqlDatabase db = DataBaseManagement::loadDatabase(_databasePath);
QList<TreeItem *> items;
QList<TreeItem *> nextLevelItems;
QSqlQuery selectQuery(db);
selectQuery.prepare("select * from folder where id <> 1 and parentId = :parentId order by parentId,name");
items << item;
bool firstLevelUpdate = false;
while(items.size() > 0)
{
nextLevelItems.clear();
foreach(TreeItem * item, items)
{
selectQuery.bindValue(":parentId", item->id);
selectQuery.exec();
//Reload all children
if(!firstLevelUpdate)
{
beginInsertRows(parent, 0, selectQuery.numRowsAffected());
firstLevelUpdate = true;
}
updateFolderModelData(selectQuery,item);
if(!firstLevelUpdate)
endInsertRows();
nextLevelItems << item->children();
}
items.clear();
items = nextLevelItems;
}
db.close();
QSqlDatabase::removeDatabase(_databasePath);
} }

View File

@ -87,7 +87,7 @@ public:
QStringList getSubfoldersNames(const QModelIndex & mi); QStringList getSubfoldersNames(const QModelIndex & mi);
void fetchMore(const QModelIndex & parent); void fetchMoreFromDB(const QModelIndex & parent);
enum Columns { enum Columns {
Name = 0, Name = 0,
@ -98,6 +98,7 @@ public:
private: private:
void setupModelData( QSqlQuery &sqlquery, TreeItem *parent); void setupModelData( QSqlQuery &sqlquery, TreeItem *parent);
void updateFolderModelData( QSqlQuery &sqlquery, TreeItem *parent);
void setupFilteredModelData( QSqlQuery &sqlquery, TreeItem *parent); void setupFilteredModelData( QSqlQuery &sqlquery, TreeItem *parent);
void setupFilteredModelData(); void setupFilteredModelData();

View File

@ -1399,6 +1399,7 @@ void LibraryWindow::updateTreeFolder()
void LibraryWindow::updateFolder(const QModelIndex & miFolder) void LibraryWindow::updateFolder(const QModelIndex & miFolder)
{ {
QLOG_DEBUG() << "UPDATE FOLDER!!!!";
updateDestination = miFolder; updateDestination = miFolder;
importWidget->setUpdateLook(); importWidget->setUpdateLook();
@ -1425,8 +1426,7 @@ void LibraryWindow::reloadAfterCopyMove()
if(getCurrentFolderIndex() == updateDestination) if(getCurrentFolderIndex() == updateDestination)
reloadCovers(); reloadCovers();
//TODO do not reload the whole model, just the current folder... foldersModel->fetchMoreFromDB(updateDestination);
foldersModel->setupModelData(QDir::cleanPath(libraries.getPath(selectedLibrary->currentText())+"/.yacreaderlibrary"));
enableNeededActions(); enableNeededActions();
} }