/* * 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 REGISTER_H #define REGISTER_H #include "gui/widgets/window.h" #include "player.h" #include #include #include class LoginData; class OkDialog; /** * Listener used while dealing with wrong data. It is used to direct the focus * to the field which contained wrong data when the Ok button was pressed on * the error notice. */ class WrongDataNoticeListener : public gcn::ActionListener { public: void setTarget(gcn::TextField *textField); void action(const gcn::ActionEvent &event); private: gcn::TextField *mTarget; }; /** * The registration dialog. * * \ingroup Interface */ class RegisterDialog : public Window, public gcn::ActionListener, public gcn::KeyListener { public: /** * Constructor. Name, password and server fields will be initialized to * the information already present in the LoginData instance. * * @see Window::Window */ RegisterDialog(LoginData *loginData); /** * Destructor */ ~RegisterDialog(); /** * Called when receiving actions from the widgets. */ void action(const gcn::ActionEvent &event); /** * Called when a key is pressed in one of the text fields. */ void keyPressed(gcn::KeyEvent &keyEvent); /** * Tell the dialog to show an email field. Value stored in the passed * string pointer. Default email from pointer. Passing NULL disables * the feature. */ static void setEmail(std::string *email); /** * Tell the dialog to show a gender selection. Value stored in the * passed Gender pointer. Default Gender from pointer. Passing NULL * disables the feature. */ static void setGender(Gender *gender); private: /** * Returns whether submit can be enabled. This is true in the register * state, when all necessary fields have some text. */ bool canSubmit() const; gcn::TextField *mUserField; gcn::TextField *mPasswordField; gcn::TextField *mConfirmField; gcn::TextField *mEmailField; gcn::Button *mRegisterButton; gcn::Button *mCancelButton; gcn::RadioButton *mMaleButton; gcn::RadioButton *mFemaleButton; WrongDataNoticeListener *mWrongDataNoticeListener; LoginData *mLoginData; static std::string *useEmail; static Gender *useGender; }; #endif