20 package net.sf.gridarta.gui.dialog.plugin;
22 import java.awt.Component;
24 import java.io.IOException;
26 import javax.swing.Action;
27 import javax.swing.JFileChooser;
28 import javax.swing.JOptionPane;
44 import net.
sf.japi.swing.action.ActionBuilder;
45 import net.
sf.japi.swing.action.ActionBuilderFactory;
46 import net.
sf.japi.swing.action.ActionMethod;
47 import net.
sf.japi.swing.action.ReflectionAction;
48 import org.jetbrains.annotations.NotNull;
61 private static final ActionBuilder
ACTION_BUILDER = ActionBuilderFactory.getInstance().getActionBuilder(
"net.sf.gridarta");
105 final String filterName =
"(s)" + plugin.getName();
107 if (plugin.isFilter()) {
108 final Filter<?, ?> filter = plugin.getPluginAsFilter(pluginParameters);
109 if (filter != null) {
110 filterControl.
addFilter(filterName, filter);
114 if (plugin.isAutoBoot()) {
115 plugin.runPlugin(pluginParameters);
120 public void pluginUnregistered(@NotNull
final Plugin<G, A, R> plugin) {
121 final String filterName =
"(s)" + plugin.getName();
130 public PluginController(@NotNull
final FilterControl<G, A, R> filterControl, @NotNull
final PluginModel<G, A, R> pluginModel, @NotNull
final PluginParameters pluginParameters, @NotNull
final Component parent, @NotNull
final PluginParameterViewFactory<G, A, R> pluginParameterViewFactory, @NotNull
final File pluginsDir, @NotNull
final ResourceIcons resourceIcons) {
137 pluginModel.addPluginModelListener(pluginModelListener);
146 if (plugin.isModified()) {
147 final int result = ACTION_BUILDER.showConfirmDialog(parent, JOptionPane.YES_NO_CANCEL_OPTION, JOptionPane.WARNING_MESSAGE,
"pluginConfirmSaveChanges", plugin.getName());
148 if (result == JOptionPane.YES_OPTION) {
152 }
else if (result == JOptionPane.CANCEL_OPTION || result == JOptionPane.CLOSED_OPTION) {
179 if (!plugin.isModified()) {
184 final File file = plugin.getFile();
192 }
catch (
final IOException ex) {
197 plugin.resetModified();
210 final JFileChooser chooser =
new JFileChooser();
211 final File pluginFile = plugin.getFile();
213 chooser.setDialogTitle(
"save plugin " + plugin.getName());
214 final int result = chooser.showSaveDialog(null);
215 if (result != JFileChooser.APPROVE_OPTION) {
219 final File file = chooser.getSelectedFile();
220 if (updatePluginFile) {
221 plugin.setFile(file);
223 pluginsDir = file.getParentFile();
227 }
catch (
final IOException ex) {
237 final Map<String, Object> runValues = view.
getRunValues(clonedPlugin, parent);
238 if (runValues == null) {
248 if (plugin != null) {
266 action.putValue(ReflectionAction.REFLECTION_ARGUMENTS,
new Object[] { plugin.getName(), });
267 action.putValue(Action.NAME, ACTION_BUILDER.format(
"runPlugin.text", plugin.getName()));
272 public void setAction(@NotNull
final Action action, @NotNull
final String name) {
Map< String, Object > getRunValues(@NotNull final Plugin< G, A, R > plugin, @NotNull final Component parent)
Asks the user for input parameter to run a plugin.
void saveAllPlugins()
Saves all modified plugins.
Graphical User Interface of Gridarta.
final PluginView< G, A, R > view
Plugin< G, A, R > getPlugin(@NotNull final String name)
final PluginParameters pluginParameters
Utility class for JFileChooser related functions.
Listener interface for scripting related events.
Utility class implementing Action related functions.
final PluginModelListener< G, A, R > pluginModelListener
The PluginModelListener attached to pluginModel.
Allows execution of Plugins.
ConsoleInterface createConsole(@NotNull final String name)
Base package of all Gridarta classes.
static void setCurrentDirectory(@NotNull final JFileChooser fileChooser, @Nullable final File dir)
Calls JFileChooser#setCurrentDirectory(File).
PluginView< G, A, R > getView()
void removeFilter(@NotNull String name)
Reflects a game object (object on a map).
boolean savePlugin(@NotNull final Plugin< G, A, R > plugin)
Saves one plugin.
String getName()
Returns the name of this plugin.
Plugin< G, A, R > clonePlugin()
Returns a clone copy of this plugin.
GameObjects are the objects based on Archetypes found on maps.
static final ActionBuilder ACTION_BUILDER
Action Builder.
The filter package contains the classes for Filters.
void savePlugin(@NotNull final Plugin< G, A, R > plugin, @NotNull final File file)
Saves a plugin to a given file.
Action createRunAction(@NotNull final Plugin< G, A, R > plugin)
Creates an action to run a plugin plugin.
Makes basic Gridarta classes available to scripts.
void addFilter(@NotNull String name, @NotNull Filter<?, ?> filter)
File pluginsDir
The default directory for saving plugins.
boolean canExit()
Prompts the user for all unsaved plugins.
void runPlugin(@NotNull final Plugin< G, A, R > plugin)
Creates ImageIcon instances from resources.
final PluginModel< G, A, R > pluginModel
PluginController(@NotNull final FilterControl< G, A, R > filterControl, @NotNull final PluginModel< G, A, R > pluginModel, @NotNull final PluginParameters pluginParameters, @NotNull final Component parent, @NotNull final PluginParameterViewFactory< G, A, R > pluginParameterViewFactory, @NotNull final File pluginsDir, @NotNull final ResourceIcons resourceIcons)
Creates a new instance.
final Component parent
The parent component for dialog boxes.
Factory for creating PluginParameterView instances.
boolean savePluginAs(@NotNull final Plugin< G, A, R > plugin, final boolean updatePluginFile)
Prompts the user for a file name to save a plugin.
void setAction(@NotNull final Action action, @NotNull final String name)
Sets the Action instance for this editor action.
void runPlugin(@NotNull final String name)
Interface for MapArchObjects.
final FilterControl< G, A, R > filterControl
static Action newAction(@NotNull final ActionBuilder actionBuilder, @NotNull final String category, @NotNull final EditorAction editorAction, @NotNull final String key)
Creates a new Action instance.