summaryrefslogtreecommitdiffstats
path: root/sigmodr/models/MapModel.cpp
blob: 8a3b51f2eed7308c6e4673ff4382308804959e6e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/*
 * 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 "MapModel.h"

// Model includes
#include "MapEffectGroupModel.h"
#include "MapTrainerGroupModel.h"
#include "MapWarpGroupModel.h"
#include "MapWildListGroupModel.h"

// Sigmodr includes
#include "../MapUI.h"

// Sigmod includes
#include "../../sigmod/Map.h"

// KDE includes
#include <KMenu>

Sigmodr::MapModel::MapModel(BaseModel* parent, Sigmod::Map* map) :
        GroupObjectModel(parent, map)
{
    setupData();
}

Sigmodr::MapModel::~MapModel()
{
    clearData();
}

QVariant Sigmodr::MapModel::data(int role) const
{
    if (role == Qt::DisplayRole)
        return qobject_cast<Sigmod::Map*>(m_object)->name();
    else if (role == Sigmodr::BaseModel::XmlRole)
    {
        QDomDocument xml(m_object->className());
        xml.appendChild(m_object->save());
        return xml.toString();
    }
    else if (role == Sigmodr::BaseModel::WidgetRole)
    {
        QWidget* widget = new MapUI(qobject_cast<Sigmod::Map*>(m_object), NULL);
        return QVariant::fromValue(widget);
    }
    else if (role == Sigmodr::BaseModel::ContextMenuRole)
    {
        KMenu* menu = new KMenu;
        menu->addAction("&Delete Map", this, SLOT(deleteSelf()));
        return QVariant::fromValue(menu);
    }
    return Sigmodr::GroupObjectModel::data(role);
}

bool Sigmodr::MapModel::setData(const QVariant& value, int role)
{
    if (role == Sigmodr::BaseModel::XmlRole)
    {
        QString data = value.toString();
        if (!data.isEmpty())
        {
            QDomDocument xml;
            if (loadFromData(data, &xml))
            {
                if (xml.doctype().name() == m_object->className())
                {
                    clearData();
                    m_object->load(xml.documentElement());
                    setupData();
                    return true;
                }
                foreach (BaseModel* model, m_objects)
                {
                    GroupModel* group = qobject_cast<GroupModel*>(model);
                    if (group && group->setData(value, role))
                        return true;
                }
            }
        }
    }
    return false;
}

QString Sigmodr::MapModel::types() const
{
    return type().append(";MapEffect;MapTrainer;MapWarp;MapWildList");
}

void Sigmodr::MapModel::addObject(Sigmod::Object* object)
{
    Q_UNUSED(object)
}

void Sigmodr::MapModel::deleteObject(BaseModel* model)
{
    Q_UNUSED(model)
}

void Sigmodr::MapModel::deleteSelf()
{
    qobject_cast<GroupModel*>(m_parent)->deleteObject(this);
}

void Sigmodr::MapModel::setupData()
{
    Sigmod::Map* map = qobject_cast<Sigmod::Map*>(m_object);
    addChild(new MapEffectGroupModel(this, map));
    addChild(new MapTrainerGroupModel(this, map));
    addChild(new MapWarpGroupModel(this, map));
    addChild(new MapWildListGroupModel(this, map));
}