summaryrefslogtreecommitdiff
path: root/src/gui/npc_text.h
blob: 4c0c31e32b9057c78da3fcc587398785df8b6a07 (plain) (blame)
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
128
129
130
/*
 *  The Mana World
 *  Copyright (C) 2004  The Mana World Development Team
 *
 *  This file is part of The Mana World.
 *
 *  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 2 of the License, or
 *  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, write to the Free Software
 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 */

#ifndef NPC_TEXT_H
#define NPC_TEXT_H

#include <string>

#include <guichan/actionlistener.hpp>

#include "window.h"

#include "../npc.h"

#ifdef EATHENA_SUPPORT
class Network;
#endif
class TextBox;

/**
 * The npc text dialog.
 *
 * \ingroup Interface
 */
class NpcTextDialog : public Window, public gcn::ActionListener
{
    public:
        /**
         * Constructor.
         *
         * @see Window::Window
         */
#ifdef TMWSERV_SUPPORT
        NpcTextDialog();
#else
        NpcTextDialog(Network *network);
#endif

        /**
         * Called when receiving actions from the widgets.
         */
        void action(const gcn::ActionEvent &event);

        /**
         * Clears the text shown in the dialog.
         */
        void clearText();

        /**
         * Sets the text shows in the dialog.
         *
         * @param string The new text.
         */
        void setText(const std::string &string);

        /**
         * Adds the text to the text shows in the dialog. Also adds a newline
         * to the end.
         *
         * @param string The text to add.
         */
        void addText(const std::string &string);

        void showNextButton();

        void showCloseButton();

        /**
         * Notifies the server that the client has performed a next action.
         */
        void nextDialog(int npcID = current_npc);

        /**
         * Notifies the server that the client has performed a close action.
         */
        void closeDialog(int npcID = current_npc);

        /**
         * Initializes window width to the last known setting. Since the dialog
         * doesn't need any extra focus outside of what it's given in the Game
         * class, this is all it does for now.
         */
        void requestFocus();

        /**
         * Called when resizing the window.
         *
         * @param event The calling event
         */
        void widgetResized(const gcn::Event &event);

    private:
#ifdef EATHENA_SUPPORT
        Network *mNetwork;
#endif
        gcn::ScrollArea *mScrollArea;
        TextBox *mTextBox;
        gcn::Button *mButton;

        std::string mText;

        enum NPCTextState {
            NPC_TEXT_STATE_WAITING,
            NPC_TEXT_STATE_NEXT,
            NPC_TEXT_STATE_CLOSE
        };
        NPCTextState mState;
};

extern NpcTextDialog *npcTextDialog;

#endif // NPC_TEXT_H