diff options
Diffstat (limited to 'pokemodr/models/AbilityGroupModel.cpp')
| -rw-r--r-- | pokemodr/models/AbilityGroupModel.cpp | 38 |
1 files changed, 33 insertions, 5 deletions
diff --git a/pokemodr/models/AbilityGroupModel.cpp b/pokemodr/models/AbilityGroupModel.cpp index 76c06764..482576cf 100644 --- a/pokemodr/models/AbilityGroupModel.cpp +++ b/pokemodr/models/AbilityGroupModel.cpp @@ -22,21 +22,49 @@ #include "AbilityModel.h" // Pokemod includes +#include "../../pokemod/Ability.h" #include "../../pokemod/Pokemod.h" +// KDE includes +#include <KMenu> + AbilityGroupModel::AbilityGroupModel(BaseModel* parent, Pokemod* pokemod) : GroupModel(parent, pokemod, "Abilities") { - setupData(); + for (int i = 0; i < pokemod->abilityCount(); ++i) + addObject(pokemod->ability(i)); } AbilityGroupModel::~AbilityGroupModel() { } -void AbilityGroupModel::setupData() +QVariant AbilityGroupModel::data(const int role) const { - Pokemod* pokemod = static_cast<Pokemod*>(m_object); - for (int i = 0; i < pokemod->abilityCount(); ++i) - m_objects.append(new AbilityModel(this, pokemod->ability(i))); + if (role == BaseModel::ContextMenuRole) + { + KMenu* menu = new KMenu; + menu->addAction("Add Ability", this, SLOT(addObject())); + return QVariant::fromValue(static_cast<void*>(menu)); + } + return GroupModel::data(role); +} + +void AbilityGroupModel::addObject(Object* object) +{ + if (!object) + object = static_cast<Pokemod*>(m_object)->newAbility(); + if (object->className() == "Ability") + m_objects.append(new AbilityModel(this, static_cast<Ability*>(object))); +} + +void AbilityGroupModel::deleteObject(BaseObjectModel* model) +{ + const int index = m_objects.indexOf(model); + if (0 <= index) + { + static_cast<Pokemod*>(m_object)->deleteAbility(index); + m_objects[index]->deleteLater(); + m_objects.removeAt(index); + } } |
