summaryrefslogtreecommitdiffstats
path: root/pokemodr/models/MapWarpGroupModel.cpp
diff options
context:
space:
mode:
authorBen Boeckel <MathStuf@gmail.com>2008-05-26 01:32:07 +0000
committerBen Boeckel <MathStuf@gmail.com>2008-05-26 01:32:07 +0000
commitff8c440c3a2aeb0e1abc6f93e9dd7775533382ff (patch)
tree302ac68425cecc61d429c64cf8676ad37d1d4f12 /pokemodr/models/MapWarpGroupModel.cpp
parent7e3bf1853184f96eb5be47dd78ebe21fdc170a01 (diff)
downloadsigen-ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff.tar.gz
sigen-ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff.tar.xz
sigen-ff8c440c3a2aeb0e1abc6f93e9dd7775533382ff.zip
[FIX] Context menus added
[FIX] No more copy/cut/paste for objects; only available from context menus [FIX] Can now add objects during runtime git-svn-id: https://pokegen.svn.sourceforge.net/svnroot/pokegen/trunk@174 6ecfd1a5-f3ed-3746-8530-beee90d26b22
Diffstat (limited to 'pokemodr/models/MapWarpGroupModel.cpp')
-rw-r--r--pokemodr/models/MapWarpGroupModel.cpp38
1 files changed, 33 insertions, 5 deletions
diff --git a/pokemodr/models/MapWarpGroupModel.cpp b/pokemodr/models/MapWarpGroupModel.cpp
index fd8bb785..a042cdc5 100644
--- a/pokemodr/models/MapWarpGroupModel.cpp
+++ b/pokemodr/models/MapWarpGroupModel.cpp
@@ -23,20 +23,48 @@
// Map includes
#include "../../pokemod/Map.h"
+#include "../../pokemod/MapWarp.h"
+
+// KDE includes
+#include <KMenu>
MapWarpGroupModel::MapWarpGroupModel(BaseModel* parent, Map* map) :
GroupModel(parent, map, "Warps")
{
- setupData();
+ for (int i = 0; i < map->warpCount(); ++i)
+ addObject(map->warp(i));
}
MapWarpGroupModel::~MapWarpGroupModel()
{
}
-void MapWarpGroupModel::setupData()
+QVariant MapWarpGroupModel::data(const int role) const
{
- Map* map = static_cast<Map*>(m_object);
- for (int i = 0; i < map->warpCount(); ++i)
- m_objects.append(new MapWarpModel(this, map->warp(i)));
+ if (role == BaseModel::ContextMenuRole)
+ {
+ KMenu* menu = new KMenu;
+ menu->addAction("Add Warp", this, SLOT(addObject()));
+ return QVariant::fromValue(static_cast<void*>(menu));
+ }
+ return GroupModel::data(role);
+}
+
+void MapWarpGroupModel::addObject(Object* object)
+{
+ if (!object)
+ object = static_cast<Map*>(m_object)->newWarp();
+ if (object->className() == "MapWarp")
+ m_objects.append(new MapWarpModel(this, static_cast<MapWarp*>(object)));
+}
+
+void MapWarpGroupModel::deleteObject(BaseObjectModel* model)
+{
+ const int index = m_objects.indexOf(model);
+ if (0 <= index)
+ {
+ static_cast<Map*>(m_object)->deleteWarp(index);
+ m_objects[index]->deleteLater();
+ m_objects.removeAt(index);
+ }
}