/**
* eAdventure (formerly <e-Adventure> and <e-Game>) is a research project of the
* <e-UCM> research group.
*
* Copyright 2005-2010 <e-UCM> research group.
*
* You can access a list of all the contributors to eAdventure at:
* http://e-adventure.e-ucm.es/contributors
*
* <e-UCM> is a research group of the Department of Software Engineering
* and Artificial Intelligence at the Complutense University of Madrid
* (School of Computer Science).
*
* C Profesor Jose Garcia Santesmases sn,
* 28040 Madrid (Madrid), Spain.
*
* For more info please visit: <http://e-adventure.e-ucm.es> or
* <http://www.e-ucm.es>
*
* ****************************************************************************
*
* This file is part of eAdventure, version 2.0
*
* eAdventure is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* eAdventure 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with eAdventure. If not, see <http://www.gnu.org/licenses/>.
*/
package es.eucm.ead.editor.view.menu;
import java.awt.event.ActionEvent;
import java.awt.event.KeyEvent;
import com.google.inject.Inject;
import es.eucm.ead.editor.R;
import es.eucm.ead.editor.control.Controller;
import es.eucm.ead.editor.model.EditorModelImpl;
import es.eucm.ead.editor.model.nodes.LogNode;
import es.eucm.ead.editor.util.Log4jConfig;
import es.eucm.ead.tools.java.utils.FileUtils;
import java.io.File;
import java.io.IOException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Default implementation of the editor menu.
*/
public class EditMenu extends AbstractEditorMenu {
private static Logger logger = LoggerFactory.getLogger(EditMenu.class);
@Inject
public EditMenu(Controller controller) {
super(controller, Messages.edit_menu);
}
/**
* Initialize the editor menu
*/
@Override
public void initialize() {
@SuppressWarnings("unchecked")
AbstractEditorAction<String>[] as = new AbstractEditorAction[] {
new UndoAction(Messages.edit_menu_undo, KeyEvent.VK_Z, 0,
R.Drawable.toolbar__undo_png),
new RedoAction(Messages.edit_menu_redo, KeyEvent.VK_U, 0,
R.Drawable.toolbar__redo_png),
null, // this is a separator
new EditorAction(Messages.edit_menu_scenes, KeyEvent.VK_S,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__scenes_png),
new EditorAction(Messages.edit_menu_player, KeyEvent.VK_P,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__player_png),
new EditorAction(Messages.edit_menu_npcs, KeyEvent.VK_N,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__npcs_png),
new EditorAction(Messages.edit_menu_conversations,
KeyEvent.VK_C, KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__conversations_png),
new EditorAction(Messages.edit_menu_items, KeyEvent.VK_I,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__items_png),
new EditorAction(Messages.edit_menu_atrezzo, KeyEvent.VK_A,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__atrezzo_png),
new EditorAction(Messages.edit_menu_books, KeyEvent.VK_B,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__books_png),
new EditorAction(Messages.edit_menu_advanced, KeyEvent.VK_V,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__advanced_png),
new EditorAction(Messages.edit_menu_cutscenes, KeyEvent.VK_T,
KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__cutscenes_png),
new EditorAction(Messages.edit_menu_adaptation_profiles,
KeyEvent.VK_P, KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__adaptationProfiles_png),
new EditorAction(Messages.edit_menu_assessment_profiles,
KeyEvent.VK_R, KeyEvent.SHIFT_DOWN_MASK,
R.Drawable.sidePanel__assessmentProfiles_png),
null, // this is a separator
new TestAction(Messages.edit_menu_test1, KeyEvent.VK_1,
KeyEvent.CTRL_DOWN_MASK,
R.Drawable.sidePanel__test1_png),
new TestAction(Messages.edit_menu_test2, KeyEvent.VK_2,
KeyEvent.CTRL_DOWN_MASK,
R.Drawable.sidePanel__test2_png),
new TestAction(Messages.edit_menu_test3, KeyEvent.VK_3,
KeyEvent.CTRL_DOWN_MASK,
R.Drawable.sidePanel__test3_png),
null, // this is a separator
new ConsoleAction(Messages.edit_menu_console, KeyEvent.VK_O,
KeyEvent.ALT_DOWN_MASK, R.Drawable.assets__log_png) };
for (AbstractEditorAction<String> a : as) {
if (a == null) {
addSeparator();
continue;
}
registerAction(a);
if (a instanceof EditorAction) {
// true edit-stuff actions listen to project changes
controller.getProjectController().addChangeListener(a);
} else {
// but classic edit-menus are only worried with command stacks
controller.getCommandManager().addChangeListener(a);
}
a.processChange(null);
}
}
public class TestAction extends EditorAction {
public TestAction(String name, int gkey, int gmask, String iconUrl) {
super(name, gkey, gmask, iconUrl);
}
public void actionPerformed(ActionEvent e) {
logger.info(e.getActionCommand());
switch (e.getActionCommand().substring(
e.getActionCommand().length() - 1).charAt(0)) {
case '1': {
logger.info("testing import...");
File dest = new File(
"/home/mfreire/code/e-ucm/e-adventure-1.x/games/x");
if (dest.exists()) {
try {
FileUtils.deleteRecursive(dest);
} catch (IOException ex) {
logger.info("Could not delete previous version", ex);
}
}
File source = new File(
"/home/mfreire/code/e-ucm/e-adventure-1.x/games/simple");
controller.getProjectController().doImport(
source.getAbsolutePath(), dest.getAbsolutePath());
logger.info("... import finished");
break;
}
case '2': {
break;
}
case '3': {
break;
}
default:
throw new IllegalArgumentException(e.getActionCommand());
}
}
@Override
public void processChange(String o) {
setEnabled(true);
}
}
public class ConsoleAction extends EditorAction {
public ConsoleAction(String name, int gkey, int gmask, String iconUrl) {
super(name, gkey, gmask, iconUrl);
}
public void processChange(String o) {
setEnabled(true);
}
public void actionPerformed(ActionEvent e) {
logger.info(e.getActionCommand());
LogNode ln = new LogNode(controller.getModel().generateId(null));
((EditorModelImpl) controller.getModel())
.registerNode(ln, "addLog");
controller.getViewController()
.addView("log", "" + ln.getId(), true);
}
}
public class EditorAction extends AbstractEditorAction<String> {
public EditorAction(String name, int gkey, int gmask, String iconUrl) {
super(name, gkey, gmask, iconUrl);
}
@Override
public void actionPerformed(ActionEvent e) {
// FIXME: implement all those pesky views
System.err.println("Invoked " + getValue(NAME));
}
@Override
public void processChange(String o) {
setEnabled(controller.getModel().getEngineModel() != null);
}
}
public class UndoAction extends AbstractEditorAction<String> {
public UndoAction(String name, int gkey, int gmask, String iconUrl) {
super(name, gkey, gmask, iconUrl);
}
@Override
public void actionPerformed(ActionEvent e) {
controller.getCommandManager().undoCommand();
}
@Override
public void processChange(String o) {
setEnabled(controller.getCommandManager().canUndo());
}
}
public class RedoAction extends AbstractEditorAction<String> {
public RedoAction(String name, int gkey, int gmask, String iconUrl) {
super(name, gkey, gmask, iconUrl);
}
@Override
public void actionPerformed(ActionEvent e) {
controller.getCommandManager().redoCommand();
}
@Override
public void processChange(String o) {
setEnabled(controller.getCommandManager().canRedo());
}
}
}