X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fjbgui%2FPDBDocFieldPreferences.java;h=96e27e6f4f88490fe58c974c5eb3ac59dd42f9e8;hb=466c5639624028f92e214121672dc409ad10514b;hp=9380380e359103cf6e363b89d0a94bca5c7102aa;hpb=fd235cc7542d6e308e054a8a76580a6c511ae631;p=jalview.git diff --git a/src/jalview/jbgui/PDBDocFieldPreferences.java b/src/jalview/jbgui/PDBDocFieldPreferences.java index 9380380..96e27e6 100644 --- a/src/jalview/jbgui/PDBDocFieldPreferences.java +++ b/src/jalview/jbgui/PDBDocFieldPreferences.java @@ -2,10 +2,9 @@ package jalview.jbgui; import jalview.ws.dbsources.PDBRestClient.PDBDocField; -import java.awt.Rectangle; import java.util.Collection; import java.util.HashMap; -import java.util.HashSet; +import java.util.LinkedHashSet; import javax.swing.JScrollPane; import javax.swing.JTable; @@ -14,7 +13,6 @@ import javax.swing.table.AbstractTableModel; @SuppressWarnings("serial") public class PDBDocFieldPreferences extends JScrollPane { - protected JTable tbl_pdbDocFieldConfig = new JTable(); protected JScrollPane scrl_pdbDocFieldConfig = new JScrollPane( @@ -22,22 +20,50 @@ public class PDBDocFieldPreferences extends JScrollPane private HashMap map = new HashMap(); - private static Collection searchSummaryFields = new HashSet(); + private static Collection searchSummaryFields = new LinkedHashSet(); + + private static Collection structureSummaryFields = new LinkedHashSet(); + + public enum PreferenceSource + { + SEARCH_SUMMARY, STRUCTURE_CHOOSER, PREFERENCES; + } - private static Collection structureSummaryFields = new HashSet(); + 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; @@ -48,13 +74,28 @@ public class PDBDocFieldPreferences extends JScrollPane 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); } @@ -83,17 +124,16 @@ public class PDBDocFieldPreferences extends JScrollPane 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; @@ -131,8 +171,30 @@ public class PDBDocFieldPreferences extends JScrollPane { // Note that the data/cell address is constant, // no matter where the cell appears onscreen. - return col == 1 || col == 2; + // !isPDBID(row, col) ensures the PDB_Id cell is never editable as it + // serves as a unique id for each row. + return (col == 1 || col == 2) && !isPDBID(row, col); + + } + /** + * Determines whether the data in a given cell is a PDB ID. + * + * @param row + * @param col + * @return + */ + + public boolean isPDBID(int row, int col) + { + boolean matched = false; + String name = getValueAt(row, 0).toString(); + PDBDocField pdbField = map.get(name); + if (pdbField == PDBDocField.PDB_ID) + { + matched = true; + } + return matched; } /* @@ -148,31 +210,41 @@ public class PDBDocFieldPreferences extends JScrollPane 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 (currentSource == PreferenceSource.STRUCTURE_CHOOSER) + { + updatePrefs(structureSummaryFields, pdbField, selected); } - else if (col == 2) + else if (currentSource == PreferenceSource.PREFERENCES) { - if (structureSummaryFields.contains(pdbField) && !selected) + 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 prefConfig, + PDBDocField pdbField, + boolean selected) + { + if (prefConfig.contains(pdbField) && !selected) + { + prefConfig.remove(pdbField); + } + + if (!prefConfig.contains(pdbField) && selected) + { + prefConfig.add(pdbField); + } } + } }