X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fde%2Ftodesbaum%2Fjsite%2Fgui%2FNodeManagerPage.java;h=49c25bc21fbd803d8950217a3fbd5c9c55c41528;hb=8bc7a8f2372639a9fbeea34f9cbee9697f34ba3f;hp=0f38a5547f65ded72aa8560f19cc4188e015126e;hpb=bb1eccdace92539e122c9e4b3b8bd1486615d688;p=jSite.git diff --git a/src/de/todesbaum/jsite/gui/NodeManagerPage.java b/src/de/todesbaum/jsite/gui/NodeManagerPage.java index 0f38a55..49c25bc 100644 --- a/src/de/todesbaum/jsite/gui/NodeManagerPage.java +++ b/src/de/todesbaum/jsite/gui/NodeManagerPage.java @@ -1,6 +1,5 @@ /* - * jSite-0.7 - - * Copyright (C) 2006 David Roden + * jSite - NodeManagerPage.java - Copyright © 2006–2012 David Roden * * 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 @@ -104,6 +103,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene setDescription(I18n.getMessage("jsite.node-manager.description")); I18nContainer.getInstance().registerRunnable(new Runnable() { + @Override public void run() { setHeading(I18n.getMessage("jsite.node-manager.heading")); setDescription(I18n.getMessage("jsite.node-manager.description")); @@ -144,11 +144,24 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene } /** + * Notifies all listeners that a new node was selected. + * + * @param node + * The newly selected node + */ + protected void fireNodeSelected(Node node) { + for (NodeManagerListener nodeManagerListener : nodeManagerListeners) { + nodeManagerListener.nodeSelected(node); + } + } + + /** * Creates all actions. */ private void createActions() { addNodeAction = new AbstractAction(I18n.getMessage("jsite.node-manager.add-node")) { + @Override @SuppressWarnings("synthetic-access") public void actionPerformed(ActionEvent actionEvent) { addNode(); @@ -157,6 +170,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene deleteNodeAction = new AbstractAction(I18n.getMessage("jsite.node-manager.delete-node")) { + @Override @SuppressWarnings("synthetic-access") public void actionPerformed(ActionEvent actionEvent) { deleteNode(); @@ -166,6 +180,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene I18nContainer.getInstance().registerRunnable(new Runnable() { + @Override public void run() { addNodeAction.putValue(Action.NAME, I18n.getMessage("jsite.node-manager.add-node")); deleteNodeAction.putValue(Action.NAME, I18n.getMessage("jsite.node-manager.delete-node")); @@ -227,6 +242,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene I18nContainer.getInstance().registerRunnable(new Runnable() { + @Override public void run() { nodeInformationLabel.setText("" + I18n.getMessage("jsite.node-manager.node-information") + ""); nodeNameLabel.setText(I18n.getMessage("jsite.node-manager.name") + ":"); @@ -347,8 +363,10 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene if (JOptionPane.showConfirmDialog(wizard, I18n.getMessage("jsite.node-manager.delete-node.warning"), null, JOptionPane.OK_CANCEL_OPTION, JOptionPane.WARNING_MESSAGE) == JOptionPane.CANCEL_OPTION) { return; } + int nodeIndex = nodeListModel.indexOf(node); nodeListModel.removeElement(node); nodeList.repaint(); + fireNodeSelected((Node) nodeListModel.get(Math.min(nodeIndex, nodeListModel.size() - 1))); fireNodesUpdated(getNodes()); deleteNodeAction.setEnabled(nodeListModel.size() > 1); wizard.setNextEnabled(nodeListModel.size() > 0); @@ -361,6 +379,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene /** * {@inheritDoc} */ + @Override @SuppressWarnings("null") public void valueChanged(ListSelectionEvent e) { Object source = e.getSource(); @@ -393,6 +412,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene /** * {@inheritDoc} */ + @Override public void insertUpdate(DocumentEvent e) { updateTextField(e); } @@ -400,6 +420,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene /** * {@inheritDoc} */ + @Override public void removeUpdate(DocumentEvent e) { updateTextField(e); } @@ -407,6 +428,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene /** * {@inheritDoc} */ + @Override public void changedUpdate(DocumentEvent e) { updateTextField(e); } @@ -418,6 +440,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene /** * {@inheritDoc} */ + @Override public void stateChanged(ChangeEvent e) { Object source = e.getSource(); Node selectedNode = getSelectedNode(); @@ -428,6 +451,7 @@ public class NodeManagerPage extends TWizardPage implements ListSelectionListene JSpinner sourceSpinner = (JSpinner) source; if ("node-port".equals(sourceSpinner.getName())) { selectedNode.setPort((Integer) sourceSpinner.getValue()); + fireNodeSelected(selectedNode); nodeList.repaint(); } }