2 * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3 * Copyright (C) $$Year-Rel$$ The Jalview Authors
5 * This file is part of Jalview.
7 * Jalview is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation, either version 3
10 * of the License, or (at your option) any later version.
12 * Jalview is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty
14 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
19 * The Jalview Authors are detailed in the 'AUTHORS' file.
23 import jalview.jbgui.GRestInputParamEditDialog;
24 import jalview.ws.params.InvalidArgumentException;
25 import jalview.ws.params.OptionI;
26 import jalview.ws.params.ParameterI;
27 import jalview.ws.rest.InputType;
28 import jalview.ws.rest.RestServiceDescription;
30 import java.util.ArrayList;
31 import java.util.Hashtable;
33 import javax.swing.JPanel;
34 import javax.swing.event.ListSelectionEvent;
36 import net.miginfocom.swing.MigLayout;
38 public class RestInputParamEditDialog extends GRestInputParamEditDialog
39 implements OptsParametersContainerI
41 Hashtable<String, Class> typeclass = new Hashtable<String, Class>();
43 Hashtable<String, ArrayList<JPanel>> typeopts = new Hashtable<String, ArrayList<JPanel>>();
45 Hashtable<String, OptsAndParamsPage> opanps = new Hashtable<String, OptsAndParamsPage>();
47 private InputType getTypeFor(String name)
51 return (InputType) (typeclass.get(name).getConstructor()
56 "Unexpected exception when instantiating rest input type.");
64 JalviewDialog frame = new JalviewDialog()
68 protected void raiseClosed()
74 protected void okPressed()
76 reply = JvOptionPane.OK_OPTION;
80 protected void cancelPressed()
82 reply = JvOptionPane.CANCEL_OPTION;
87 InputType old, current;
89 public RestInputParamEditDialog(
90 RestServiceEditorPane restServiceEditorPane,
91 RestServiceDescription currentservice, InputType toedit)
93 initFor(restServiceEditorPane, currentservice, toedit);
95 // TODO: warn user if they are about to overwrite an existing parameter
96 // because they have used the same name when editing a different parameter.
97 // TODO: make any press of the return key cause 'OK' to be pressed
100 private void initFor(RestServiceEditorPane restServiceEditorPane,
101 RestServiceDescription currentservice, InputType toedit)
103 okcancel.add(frame.cancel);
104 okcancel.add(frame.ok);
105 frame.initDialogFrame(dpane, true, true,
106 "Edit parameter for service " + currentservice.getName(), 600,
110 reply = JvOptionPane.CANCEL_OPTION;
117 updated = updated && reply == JvOptionPane.OK_OPTION;
121 public RestInputParamEditDialog(
122 RestServiceEditorPane restServiceEditorPane,
123 RestServiceDescription currentservice, String string)
125 initFor(restServiceEditorPane, currentservice, null);
127 frame.waitForInput();
130 private void setStateFor(InputType current)
132 tok.setText(current.token);
133 OptsAndParamsPage opanp = opanps.get(current.getURLtokenPrefix());
134 for (OptionI ops : current.getOptions())
136 if (ops instanceof ParameterI)
138 opanp.setParameter((ParameterI) ops);
142 if (ops.getValue() != null && ops.getValue().length() > 0)
144 opanp.selectOption(ops, ops.getValue());
148 typeList.setSelectedValue(current.getURLtokenPrefix(), true);
149 type_SelectionChangedActionPerformed(null);
152 private void updateCurrentType()
154 if (typeList.getSelectedValue() != null)
156 InputType newType = getTypeFor((String) typeList.getSelectedValue());
159 newType.token = tok.getText().trim();
162 newType.configureFromArgumentI(opanps
163 .get(newType.getURLtokenPrefix()).getCurrentSettings());
166 } catch (InvalidArgumentException ex)
169 "IMPLEMENTATION ERROR: Invalid argument for type : "
170 + typeList.getSelectedValue() + "\n");
171 ex.printStackTrace();
178 private void initTypeLists()
180 ArrayList<String> types = new ArrayList<String>();
181 // populate type list
182 for (Class type : RestServiceDescription.getInputTypes())
185 InputType jtype = null;
188 JPanel inopts = new JPanel(new MigLayout());
189 ArrayList<JPanel> opts = new ArrayList<JPanel>(),
190 prms = new ArrayList<JPanel>();
191 jtype = (InputType) (type.getConstructor().newInstance());
192 typeclass.put(jtype.getURLtokenPrefix(), type);
193 // and populate parameters from this type
194 OptsAndParamsPage opanp = new OptsAndParamsPage(this, true);
195 opanps.put(jtype.getURLtokenPrefix(), opanp);
196 for (OptionI opt : jtype.getOptions())
199 if (opt instanceof ParameterI)
201 prms.add(opanp.addParameter((ParameterI) opt));
205 opts.add(opanp.addOption(opt));
208 // then tag the params at the end of the options.
209 for (JPanel pnl : prms)
213 typeopts.put(jtype.getURLtokenPrefix(), opts);
214 types.add(jtype.getURLtokenPrefix());
215 } catch (Throwable x)
218 "Unexpected exception when instantiating rest input type.");
222 typeList.setListData(types.toArray());
227 protected void type_SelectionChangedActionPerformed(ListSelectionEvent e)
230 String typen = (String) typeList.getSelectedValue();
231 if (typeopts.get(typen) != null)
233 for (JPanel opt : typeopts.get(typen))
236 options.add(opt, "wrap");
238 options.invalidate();
239 optionsPanel.setVisible(true);
243 optionsPanel.setVisible(false);
249 boolean updated = false;
251 public boolean wasUpdated()
257 public void refreshParamLayout()
259 options.invalidate();
264 protected void tokChanged_actionPerformed()
266 if (tok.getText().trim().length() > 0)
270 current.token = tok.getText().trim();
277 public void argSetModified(Object modifiedElement, boolean b)
279 updated = updated | b;