/* * 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 "MapWildListModel.h" // Model includes #include "MapWildListEncounterModel.h" // PokeModr includes #include "../MapWildListUI.h" // Pokemod includes #include "../../pokemod/Map.h" #include "../../pokemod/MapWildList.h" // Qt includes #include MapWildListModel::MapWildListModel(BaseModel* parent, MapWildList* wildList) : GroupObjectModel(parent, wildList) { setupData(); } MapWildListModel::~MapWildListModel() { clearData(); } QVariant MapWildListModel::data(int role) const { if (role == Qt::DisplayRole) { if (static_cast(m_object)->control() < MapWildList::End) return MapWildList::ControlStr[static_cast(m_object)->control()]; return ""; } else if (role == BaseModel::XmlRole) { QDomDocument xml(m_object->className()); xml.appendChild(m_object->save()); return xml.toString(); } else if (role == BaseModel::WidgetRole) { QWidget* widget = new MapWildListUI(static_cast(m_object), NULL); return QVariant::fromValue(widget); } return GroupObjectModel::data(role); } bool MapWildListModel::setData(const QVariant& value, int role) { if (role == BaseModel::XmlRole) { if (value.canConvert()) { QFile file(value.toString()); QDomDocument xml; if ((file.open(QIODevice::ReadOnly) && xml.setContent(&file)) || xml.setContent(value.toString())) { if (xml.doctype().name() == m_object->className()) { clearData(); m_object->load(xml.documentElement()); setupData(); return true; } file.close(); } } } return false; } bool MapWildListModel::insertRows(const int rows) { for (int i = 0; i < rows; ++i) m_objects.append(new MapWildListEncounterModel(this, static_cast(m_object)->newEncounter())); return true; } bool MapWildListModel::removeRows(const int position, const int rows) { for (int i = 0; i < rows; ++i) { static_cast(m_object)->deleteEncounter(position); delete m_objects[position]; m_objects.removeAt(position); } return true; } void MapWildListModel::setupData() { MapWildList* wildList = static_cast(m_object); for (int i = 0; i < wildList->encounterCount(); ++i) m_objects.append(new MapWildListEncounterModel(this, wildList->encounter(i))); }