import jalview.ws.dbsources.PDBRestClient.PDBDocField;
-import java.awt.Rectangle;
import java.util.Collection;
import java.util.HashMap;
import java.util.HashSet;
@SuppressWarnings("serial")
public class PDBDocFieldPreferences extends JScrollPane
{
-
protected JTable tbl_pdbDocFieldConfig = new JTable();
protected JScrollPane scrl_pdbDocFieldConfig = new JScrollPane(
private static Collection<PDBDocField> structureSummaryFields = new HashSet<PDBDocField>();
+ public enum PreferenceSource
+ {
+ SEARCH_SUMMARY, STRUCTURE_CHOOSER, PREFERENCES;
+ }
+
+ private PreferenceSource currentSource;
+
static
{
searchSummaryFields.add(PDBDocField.PDB_ID);
searchSummaryFields.add(PDBDocField.TITLE);
+
structureSummaryFields.add(PDBDocField.PDB_ID);
structureSummaryFields.add(PDBDocField.TITLE);
}
- public PDBDocFieldPreferences(Rectangle position)
+ public PDBDocFieldPreferences(PreferenceSource source)
{
- this.setBounds(position);
+ tbl_pdbDocFieldConfig.setAutoCreateRowSorter(true);
this.getViewport().add(tbl_pdbDocFieldConfig);
+ this.currentSource = source;
+
+ String[] columnNames = null;
+ switch (source)
+ {
+ case SEARCH_SUMMARY:
+ columnNames = new String[]
+ { "PDB Feild", "Show in search summary" };
+ break;
+ case STRUCTURE_CHOOSER:
+ columnNames = new String[]
+ { "PDB Feild", "Show in structure summary" };
+ break;
+ case PREFERENCES:
+ columnNames = new String[]
+ { "PDB Feild", "Show in search summary", "Show in structure summary" };
+ break;
+ default:
+ break;
+ }
Object[][] data = new Object[PDBDocField.values().length - 1][3];
int x = 0;
continue;
}
- data[x++] = new Object[]
- { field.getName(), searchSummaryFields.contains(field),
- structureSummaryFields.contains(field) };
+ switch (source)
+ {
+ case SEARCH_SUMMARY:
+ data[x++] = new Object[]
+ { field.getName(), searchSummaryFields.contains(field) };
+ break;
+ case STRUCTURE_CHOOSER:
+ data[x++] = new Object[]
+ { field.getName(), structureSummaryFields.contains(field) };
+ break;
+ case PREFERENCES:
+ data[x++] = new Object[]
+ { field.getName(), searchSummaryFields.contains(field),
+ structureSummaryFields.contains(field) };
+ break;
+ default:
+ break;
+ }
map.put(field.getName(), field);
}
- PDBFieldTableModel model = new PDBFieldTableModel(data);
+ PDBFieldTableModel model = new PDBFieldTableModel(columnNames, data);
tbl_pdbDocFieldConfig.setModel(model);
}
class PDBFieldTableModel extends AbstractTableModel
{
- public PDBFieldTableModel(Object[][] data)
+ public PDBFieldTableModel(String[] columnNames, Object[][] data)
{
this.data = data;
+ this.columnNames = columnNames;
}
- private String[] columnNames = new String[]
- { "PDB Feild", "Show in search summary",
- "Show in structure chooser summary" };
-
private Object[][] data;
+ private String[] columnNames;
+
public int getColumnCount()
{
return columnNames.length;
PDBDocField pdbField = map.get(name);
- if (col == 1)
+ if (currentSource == PreferenceSource.SEARCH_SUMMARY)
{
- if (searchSummaryFields.contains(pdbField) && !selected)
- {
- searchSummaryFields.remove(pdbField);
- }
-
- if (!searchSummaryFields.contains(pdbField) && selected)
- {
- searchSummaryFields.add(pdbField);
- }
+ updatePrefs(searchSummaryFields, pdbField, selected);
}
- else if (col == 2)
+ else if (currentSource == PreferenceSource.STRUCTURE_CHOOSER)
{
- if (structureSummaryFields.contains(pdbField) && !selected)
+ updatePrefs(structureSummaryFields, pdbField, selected);
+ }
+ else if (currentSource == PreferenceSource.PREFERENCES)
+ {
+ if (col == 1)
{
- structureSummaryFields.remove(pdbField);
+ updatePrefs(searchSummaryFields, pdbField, selected);
}
-
- if (!structureSummaryFields.contains(pdbField) && selected)
+ else if (col == 2)
{
- structureSummaryFields.add(pdbField);
+ updatePrefs(structureSummaryFields, pdbField, selected);
}
}
+ }
+
+ private void updatePrefs(Collection<PDBDocField> prefConfig,
+ PDBDocField pdbField,
+ boolean selected)
+ {
+ if (prefConfig.contains(pdbField) && !selected)
+ {
+ prefConfig.remove(pdbField);
+ }
+ if (!prefConfig.contains(pdbField) && selected)
+ {
+ prefConfig.add(pdbField);
+ }
}
+
}
}