diff options
Diffstat (limited to 'sigmodr/models/MapGroupModel.cpp')
| -rw-r--r-- | sigmodr/models/MapGroupModel.cpp | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/sigmodr/models/MapGroupModel.cpp b/sigmodr/models/MapGroupModel.cpp new file mode 100644 index 00000000..39482455 --- /dev/null +++ b/sigmodr/models/MapGroupModel.cpp @@ -0,0 +1,95 @@ +/* + * Copyright 2008 Ben Boeckel <MathStuf@gmail.com> + * + * 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 <http://www.gnu.org/licenses/>. + */ + +// Header include +#include "MapGroupModel.h" + +// Model includes +#include "MapModel.h" + +// Pokemod includes +#include "../../pokemod/Map.h" +#include "../../pokemod/Pokemod.h" + +// Qt includes +#include <QtCore/QFile> + +// KDE includes +#include <KMenu> + +Pokemodr::MapGroupModel::MapGroupModel(BaseModel* parent, Pokemod::Pokemod* pokemod) : + GroupModel(parent, pokemod, "Maps") +{ + for (int i = 0; i < pokemod->mapCount(); ++i) + addObject(pokemod->map(i)); +} + +Pokemodr::MapGroupModel::~MapGroupModel() +{ +} + +QVariant Pokemodr::MapGroupModel::data(const int role) const +{ + if (role == Pokemodr::BaseModel::ContextMenuRole) + { + KMenu* menu = new KMenu; + menu->addAction("&Add Map", this, SLOT(addObject())); + return QVariant::fromValue(menu); + } + return Pokemodr::GroupModel::data(role); +} + +bool Pokemodr::MapGroupModel::setData(const QVariant& value, int role) +{ + if (role == Pokemodr::BaseModel::XmlRole) + { + if (value.canConvert<QString>()) + { + QFile file(value.toString()); + QDomDocument xml; + if ((file.open(QIODevice::ReadOnly) && xml.setContent(&file)) || xml.setContent(value.toString())) + { + if (xml.doctype().name() == "Map") + { + addObject(qobject_cast<Pokemod::Pokemod*>(m_object)->newMap(xml.documentElement())); + return true; + } + file.close(); + } + } + } + return false; +} + +void Pokemodr::MapGroupModel::addObject(Pokemod::Object* object) +{ + if (!object) + object = qobject_cast<Pokemod::Pokemod*>(m_object)->newMap(); + if (object->className() == "Map") + m_objects.append(new MapModel(this, qobject_cast<Pokemod::Map*>(object))); +} + +void Pokemodr::MapGroupModel::deleteObject(BaseObjectModel* model) +{ + const int index = m_objects.indexOf(model); + if (0 <= index) + { + qobject_cast<Pokemod::Pokemod*>(m_object)->deleteMap(index); + m_objects[index]->deleteLater(); + m_objects.removeAt(index); + } +} |
