mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-23 18:53:36 +02:00
refactoring to use vector of smart pointers
This commit is contained in:
parent
db8ad8c666
commit
31ded8c6a9
@ -16,7 +16,7 @@ Item {
|
|||||||
list.model.addData(text)
|
list.model.addData(text)
|
||||||
list.selectItemById(list.model.lastInsertId());
|
list.selectItemById(list.model.lastInsertId());
|
||||||
} else {
|
} else {
|
||||||
list.model.setData(index, text)
|
list.model.setTitle(index, text)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,51 +10,50 @@ int AbstractListModel::rowCount(const QModelIndex & parent) const { Q_UNUSED(par
|
|||||||
return baseModelCount() + (virtualItemShown() ? 1 : 0);
|
return baseModelCount() + (virtualItemShown() ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
//QVariant AbstractListModel::data(const QModelIndex & index, int role) const {
|
QVariant AbstractListModel::data(const QModelIndex & index, int role) const {
|
||||||
// BaseModel model = baseModel();
|
BaseModel* model = NULL;
|
||||||
|
|
||||||
// if (virtualItemShown() && index.row() == rowCount() - 1) {
|
if (virtualItemShown() && index.row() == rowCount() - 1) {
|
||||||
// model.setValue("title", BaseModel::Value(QString("Untitled")));
|
if (role == Qt::DisplayRole) return "Untitled";
|
||||||
// } else {
|
return "";
|
||||||
// model = atIndex(index.row());
|
} else {
|
||||||
// }
|
model = atIndex(index.row());
|
||||||
|
}
|
||||||
|
|
||||||
// if (role == Qt::DisplayRole) {
|
if (role == Qt::DisplayRole) {
|
||||||
// return model.value("title").toQVariant();
|
return model->value("title").toQVariant();
|
||||||
// }
|
}
|
||||||
|
|
||||||
// if (role == IdRole) {
|
if (role == IdRole) {
|
||||||
// return model.id().toQVariant();
|
return model->id().toQVariant();
|
||||||
// }
|
}
|
||||||
|
|
||||||
// return QVariant();
|
return QVariant();
|
||||||
//}
|
}
|
||||||
|
|
||||||
//BaseModel AbstractListModel::atIndex(int index) const {
|
BaseModel* AbstractListModel::atIndex(int index) const {
|
||||||
// if (cache_.size()) {
|
qFatal("AbstractListModel::atIndex() not implemented");
|
||||||
// if (index < 0 || index >= cache_.size()) {
|
return NULL;
|
||||||
// qWarning() << "Invalid folder index:" << index;
|
}
|
||||||
// return Folder();
|
|
||||||
// }
|
|
||||||
|
|
||||||
// return cache_[index];
|
BaseModel* AbstractListModel::atIndex(const QModelIndex &index) const {
|
||||||
// }
|
return atIndex(index.row());
|
||||||
|
}
|
||||||
|
|
||||||
// cache_.clear();
|
bool AbstractListModel::setData(const QModelIndex &index, const QVariant &value, int role) {
|
||||||
|
BaseModel* model = atIndex(index.row());
|
||||||
|
if (!model) return false;
|
||||||
|
|
||||||
// cache_ = Folder::all(orderBy_);
|
if (role == Qt::EditRole) {
|
||||||
|
model->setValue("title", value);
|
||||||
|
if (!model->save()) return false;
|
||||||
|
cacheClear();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// if (!cache_.size()) {
|
qWarning() << "Unsupported role" << role;
|
||||||
// qWarning() << "Invalid folder index:" << index;
|
return false;
|
||||||
// return Folder();
|
}
|
||||||
// } else {
|
|
||||||
// return atIndex(index);
|
|
||||||
// }
|
|
||||||
//}
|
|
||||||
|
|
||||||
//BaseModel AbstractListModel::atIndex(const QModelIndex &index) const {
|
|
||||||
// return atIndex(index.row());
|
|
||||||
//}
|
|
||||||
|
|
||||||
int AbstractListModel::baseModelCount() const {
|
int AbstractListModel::baseModelCount() const {
|
||||||
qFatal("AbstractListModel::baseModelCount() not implemented");
|
qFatal("AbstractListModel::baseModelCount() not implemented");
|
||||||
|
@ -20,9 +20,10 @@ public:
|
|||||||
|
|
||||||
AbstractListModel();
|
AbstractListModel();
|
||||||
int rowCount(const QModelIndex & parent = QModelIndex()) const;
|
int rowCount(const QModelIndex & parent = QModelIndex()) const;
|
||||||
//QVariant data(const QModelIndex & index, int role = Qt::DisplayRole) const;
|
QVariant data(const QModelIndex & index, int role = Qt::DisplayRole) const;
|
||||||
// BaseModel atIndex(int index) const;
|
virtual BaseModel* atIndex(int index) const;
|
||||||
// BaseModel atIndex(const QModelIndex &index) const;
|
BaseModel* atIndex(const QModelIndex &index) const;
|
||||||
|
bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
@ -11,51 +11,14 @@ FolderModel::FolderModel() : AbstractListModel(), orderBy_("title") {
|
|||||||
connect(&dispatcher(), SIGNAL(allFoldersDeleted()), this, SLOT(dispatcher_allFoldersDeleted()));
|
connect(&dispatcher(), SIGNAL(allFoldersDeleted()), this, SLOT(dispatcher_allFoldersDeleted()));
|
||||||
}
|
}
|
||||||
|
|
||||||
QVariant FolderModel::data(const QModelIndex & index, int role) const {
|
BaseModel* FolderModel::atIndex(int index) const {
|
||||||
Folder* folder = NULL;
|
|
||||||
|
|
||||||
if (virtualItemShown() && index.row() == rowCount() - 1) {
|
|
||||||
if (role == Qt::DisplayRole) return "Untitled";
|
|
||||||
return "";
|
|
||||||
//folder->setValue("title", BaseModel::Value(QString("Untitled")));
|
|
||||||
} else {
|
|
||||||
folder = atIndex(index.row());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (role == Qt::DisplayRole) {
|
|
||||||
return folder->value("title").toQVariant();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (role == IdRole) {
|
|
||||||
return folder->id().toQVariant();
|
|
||||||
}
|
|
||||||
|
|
||||||
return QVariant();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool FolderModel::setData(const QModelIndex &index, const QVariant &value, int role) {
|
|
||||||
Folder* folder = atIndex(index.row());
|
|
||||||
if (!folder) return false;
|
|
||||||
|
|
||||||
if (role == Qt::EditRole) {
|
|
||||||
folder->setValue("title", value);
|
|
||||||
if (!folder->save()) return false;
|
|
||||||
cacheClear();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
qWarning() << "Unsupported role" << role;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
Folder* FolderModel::atIndex(int index) const {
|
|
||||||
if (cacheSize()) {
|
if (cacheSize()) {
|
||||||
if (index < 0 || index >= cacheSize()) {
|
if (index < 0 || index >= cacheSize()) {
|
||||||
qWarning() << "Invalid folder index:" << index;
|
qWarning() << "Invalid folder index:" << index;
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (Folder*)cacheGet(index);
|
return cacheGet(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
cacheClear();
|
cacheClear();
|
||||||
@ -70,8 +33,39 @@ Folder* FolderModel::atIndex(int index) const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Folder* FolderModel::atIndex(const QModelIndex &index) const {
|
QString FolderModel::indexToId(int index) const {
|
||||||
return atIndex(index.row());
|
return data(this->index(index), IdRole).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
int FolderModel::idToIndex(const QString &id) const {
|
||||||
|
int count = this->rowCount();
|
||||||
|
for (int i = 0; i < count; i++) {
|
||||||
|
Folder* folder = (Folder*)atIndex(i);
|
||||||
|
if (folder->idString() == id) return i;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString FolderModel::lastInsertId() const {
|
||||||
|
return lastInsertId_;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool FolderModel::setTitle(int index, const QVariant &value, int role) {
|
||||||
|
return setData(this->index(index), value, role);
|
||||||
|
}
|
||||||
|
|
||||||
|
void FolderModel::addData(const QString &title) {
|
||||||
|
Folder folder;
|
||||||
|
folder.setValue("title", title);
|
||||||
|
if (!folder.save()) return;
|
||||||
|
|
||||||
|
lastInsertId_ = folder.id().toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
void FolderModel::deleteData(const int index) {
|
||||||
|
Folder* folder = (Folder*)atIndex(index);
|
||||||
|
if (!folder) return;
|
||||||
|
folder->dispose();
|
||||||
}
|
}
|
||||||
|
|
||||||
int FolderModel::baseModelCount() const {
|
int FolderModel::baseModelCount() const {
|
||||||
@ -99,41 +93,6 @@ int FolderModel::cacheSize() const {
|
|||||||
return cache_.size();
|
return cache_.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
QString FolderModel::indexToId(int index) const {
|
|
||||||
return data(this->index(index), IdRole).toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
int FolderModel::idToIndex(const QString &id) const {
|
|
||||||
int count = this->rowCount();
|
|
||||||
for (int i = 0; i < count; i++) {
|
|
||||||
Folder* folder = atIndex(i);
|
|
||||||
if (folder->idString() == id) return i;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
QString FolderModel::lastInsertId() const {
|
|
||||||
return lastInsertId_;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool FolderModel::setData(int index, const QVariant &value, int role) {
|
|
||||||
return setData(this->index(index), value, role);
|
|
||||||
}
|
|
||||||
|
|
||||||
void FolderModel::addData(const QString &title) {
|
|
||||||
Folder folder;
|
|
||||||
folder.setValue("title", title);
|
|
||||||
if (!folder.save()) return;
|
|
||||||
|
|
||||||
lastInsertId_ = folder.id().toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
void FolderModel::deleteData(const int index) {
|
|
||||||
Folder* folder = atIndex(index);
|
|
||||||
if (!folder) return;
|
|
||||||
folder->dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: instead of clearing the whole cache every time, the individual items
|
// TODO: instead of clearing the whole cache every time, the individual items
|
||||||
// could be created/updated/deleted
|
// could be created/updated/deleted
|
||||||
|
|
||||||
|
@ -18,14 +18,10 @@ public:
|
|||||||
FolderModel();
|
FolderModel();
|
||||||
|
|
||||||
void addFolder(Folder* folder);
|
void addFolder(Folder* folder);
|
||||||
QVariant data(const QModelIndex & index, int role = Qt::DisplayRole) const;
|
BaseModel* atIndex(int index) const;
|
||||||
bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
|
|
||||||
Folder* atIndex(int index) const;
|
|
||||||
Folder* atIndex(const QModelIndex &index) const;
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
//BaseModel newBaseModel() const;
|
|
||||||
int baseModelCount() const;
|
int baseModelCount() const;
|
||||||
BaseModel* cacheGet(int index) const;
|
BaseModel* cacheGet(int index) const;
|
||||||
void cacheSet(int index, BaseModel *baseModel) const;
|
void cacheSet(int index, BaseModel *baseModel) const;
|
||||||
@ -45,7 +41,7 @@ public slots:
|
|||||||
|
|
||||||
void addData(const QString& title);
|
void addData(const QString& title);
|
||||||
void deleteData(const int index);
|
void deleteData(const int index);
|
||||||
bool setData(int index, const QVariant &value, int role = Qt::EditRole);
|
bool setTitle(int index, const QVariant &value, int role = Qt::EditRole);
|
||||||
QString indexToId(int index) const;
|
QString indexToId(int index) const;
|
||||||
int idToIndex(const QString& id) const;
|
int idToIndex(const QString& id) const;
|
||||||
QString lastInsertId() const;
|
QString lastInsertId() const;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user