From 18efef142da109d395d3d9761225a4936dee9e4d Mon Sep 17 00:00:00 2001 From: Ben Boeckel Date: Mon, 23 Feb 2009 11:34:15 -0500 Subject: Moved the tree for sigmods in sigmodr to a library --- sigmodr/tree/MapGroupModel.cpp | 94 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 94 insertions(+) create mode 100644 sigmodr/tree/MapGroupModel.cpp (limited to 'sigmodr/tree/MapGroupModel.cpp') diff --git a/sigmodr/tree/MapGroupModel.cpp b/sigmodr/tree/MapGroupModel.cpp new file mode 100644 index 00000000..2d122828 --- /dev/null +++ b/sigmodr/tree/MapGroupModel.cpp @@ -0,0 +1,94 @@ +/* + * Copyright 2008 Ben Boeckel + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License along + * with this program. If not, see . + */ + +// Header include +#include "MapGroupModel.h" + +// Model includes +#include "MapModel.h" + +// Sigmod includes +#include "../../sigmod/Map.h" +#include "../../sigmod/Sigmod.h" + +// KDE includes +#include + +Sigmodr::MapGroupModel::MapGroupModel(BaseModel* parent, Sigmod::Sigmod* sigmod) : + GroupModel(parent, sigmod, "Maps") +{ + for (int i = 0; i < sigmod->mapCount(); ++i) + addObject(sigmod->map(i)); +} + +Sigmodr::MapGroupModel::~MapGroupModel() +{ +} + +QVariant Sigmodr::MapGroupModel::data(const int role) const +{ + if (role == Sigmodr::BaseModel::ContextMenuRole) + { + KMenu* menu = new KMenu; + menu->addAction("&Add Map", this, SLOT(addObject())); + return QVariant::fromValue(menu); + } + return Sigmodr::GroupModel::data(role); +} + +bool Sigmodr::MapGroupModel::setData(const QVariant& value, int role) +{ + if (role == Sigmodr::BaseModel::XmlRole) + { + QString data = value.toString(); + if (!data.isEmpty()) + { + QDomDocument xml; + if (loadFromData(data, &xml) && (xml.doctype().name() == "Map")) + { + addObject(qobject_cast(m_object)->newMap(xml.documentElement())); + return true; + } + } + } + return false; +} + +QString Sigmodr::MapGroupModel::types() const +{ + return "Map"; +} + +void Sigmodr::MapGroupModel::addObject(Sigmod::Object* object) +{ + if (!object) + object = qobject_cast(m_object)->newMap(); + if (object->className() == "Map") + addChild(new MapModel(this, qobject_cast(object))); +} + +void Sigmodr::MapGroupModel::deleteObject(BaseModel* model) +{ + const int index = find(model); + if (0 <= index) + { + qobject_cast(m_object)->deleteMap(index); + m_objects[index]->deleteLater(); + m_objects.removeAt(index); + childRowChanged(index); + } +} -- cgit