mirror of
https://bitbucket.org/smil3y/kde-extraapps.git
synced 2025-02-26 11:52:54 +00:00
210 lines
5.3 KiB
C++
210 lines
5.3 KiB
C++
/*
|
|
* Copyright (C) 2007, 2008, 2009, 2010 Ivan Cukic <ivan.cukic(at)kde.org>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser/Library General Public License version 2,
|
|
* or (at your option) any later version, as published by the Free
|
|
* Software Foundation
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser/Library General Public License for more details
|
|
*
|
|
* You should have received a copy of the GNU Lesser/Library General Public
|
|
* License along with this program; if not, write to the
|
|
* Free Software Foundation, Inc.,
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*/
|
|
|
|
#include "StandardActionTreeModel.h"
|
|
|
|
#include <iostream>
|
|
|
|
namespace Lancelot
|
|
{
|
|
|
|
class StandardActionTreeModel::Private {
|
|
public:
|
|
Item * root;
|
|
bool deleteRoot;
|
|
QHash < Item * , StandardActionTreeModel * > childModels;
|
|
};
|
|
|
|
StandardActionTreeModel::Item::Item(QString itemTitle,
|
|
QString itemDescription, QIcon itemIcon, QVariant itemData)
|
|
: title(itemTitle), description(itemDescription), icon(itemIcon), data(itemData)
|
|
{
|
|
}
|
|
|
|
StandardActionTreeModel::Item::~Item()
|
|
{
|
|
qDeleteAll(children);
|
|
}
|
|
|
|
StandardActionTreeModel::StandardActionTreeModel()
|
|
: ActionTreeModel(), d(new Private())
|
|
{
|
|
d->root = new Item();
|
|
d->deleteRoot = true;
|
|
}
|
|
|
|
StandardActionTreeModel::StandardActionTreeModel(Item * root)
|
|
: ActionTreeModel(), d(new Private())
|
|
{
|
|
if (!root) {
|
|
d->root = new Item();
|
|
d->deleteRoot = true;
|
|
} else {
|
|
d->root = root;
|
|
}
|
|
}
|
|
|
|
StandardActionTreeModel::~StandardActionTreeModel()
|
|
{
|
|
if (d->deleteRoot) {
|
|
qDeleteAll(d->childModels);
|
|
delete d->root;
|
|
}
|
|
delete d;
|
|
}
|
|
|
|
StandardActionTreeModel::Item * StandardActionTreeModel::root() const
|
|
{
|
|
return d->root;
|
|
}
|
|
|
|
ActionTreeModel * StandardActionTreeModel::child(int index)
|
|
{
|
|
if (index < 0 || index >= d->root->children.size()) {
|
|
return NULL;
|
|
}
|
|
|
|
Item * childItem = d->root->children.value(index);
|
|
|
|
if (childItem->children.size() == 0) {
|
|
return NULL;
|
|
}
|
|
|
|
if (!d->childModels.contains(childItem)) {
|
|
d->childModels[childItem] = // new StandardActionTreeModel(childItem);
|
|
createChild(index);
|
|
}
|
|
|
|
return d->childModels[childItem];
|
|
}
|
|
|
|
bool StandardActionTreeModel::isCategory(int index) const
|
|
{
|
|
if (index < 0 || index >= d->root->children.size()) {
|
|
return false;
|
|
}
|
|
|
|
// std::cout << "### index # " << index << "\n";
|
|
// std::cout << " d # " << (void *)d << "\n";
|
|
// std::cout << " d->root # " << (void *)d->root << "\n";
|
|
// std::cout << " children # " << d->root->children.size() << "\n\n";
|
|
// foreach (Item i, d->root->children) {
|
|
// std::cout << qPrintable(i.title) << "\n";
|
|
// }
|
|
|
|
return d->root->children.at(index)->children.size() != 0;
|
|
}
|
|
|
|
QString StandardActionTreeModel::selfTitle() const
|
|
{
|
|
return d->root->title;
|
|
}
|
|
|
|
QIcon StandardActionTreeModel::selfIcon() const
|
|
{
|
|
return d->root->icon;
|
|
}
|
|
|
|
QString StandardActionTreeModel::title(int index) const
|
|
{
|
|
if (index < 0 || index >= d->root->children.size()) {
|
|
return QString();
|
|
}
|
|
|
|
return d->root->children.at(index)->title;
|
|
}
|
|
|
|
QString StandardActionTreeModel::description(int index) const
|
|
{
|
|
if (index < 0 || index >= d->root->children.size()) {
|
|
return QString();
|
|
}
|
|
|
|
return d->root->children.at(index)->description;
|
|
}
|
|
|
|
QIcon StandardActionTreeModel::icon(int index) const
|
|
{
|
|
if (index < 0 || index >= d->root->children.size()) {
|
|
return QIcon();
|
|
}
|
|
|
|
return d->root->children.at(index)->icon;
|
|
}
|
|
|
|
QVariant StandardActionTreeModel::data(int index) const
|
|
{
|
|
if (index < 0 || index >= d->root->children.size()) {
|
|
return QVariant();
|
|
}
|
|
|
|
return d->root->children.at(index)->data;
|
|
}
|
|
|
|
int StandardActionTreeModel::size() const
|
|
{
|
|
return d->root->children.size();
|
|
}
|
|
|
|
void StandardActionTreeModel::add(Item * item, Item * parent)
|
|
{
|
|
if (parent == NULL) parent = d->root;
|
|
|
|
parent->children << item;
|
|
}
|
|
|
|
void StandardActionTreeModel::add(const QString & title, const QString & description, QIcon icon, const QVariant & data, Item * parent)
|
|
{
|
|
add(new Item(title, description, icon, data), parent);
|
|
}
|
|
|
|
void StandardActionTreeModel::set(int index, Item * item, Item * parent)
|
|
{
|
|
if (parent == NULL) parent = d->root;
|
|
if (index < 0 || index >= parent->children.size()) return;
|
|
|
|
delete parent->children[index];
|
|
parent->children[index] = item;
|
|
}
|
|
|
|
void StandardActionTreeModel::set(int index, const QString & title, const QString & description, QIcon icon, const QVariant & data, Item * parent)
|
|
{
|
|
set(index, new Item(title, description, icon, data), parent);
|
|
}
|
|
|
|
void StandardActionTreeModel::removeAt(int index, Item * parent)
|
|
{
|
|
if (parent == NULL) parent = d->root;
|
|
parent->children.removeAt(index);
|
|
}
|
|
|
|
void StandardActionTreeModel::clear(Item * parent)
|
|
{
|
|
if (parent == NULL) parent = d->root;
|
|
parent->children.clear();
|
|
}
|
|
|
|
StandardActionTreeModel::Item * StandardActionTreeModel::itemAt(int index, Item * parent)
|
|
{
|
|
if (parent == NULL) parent = d->root;
|
|
return parent->children[index];
|
|
}
|
|
|
|
} // namespace Lancelot
|
|
|