X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FSplitFrame.java;h=f9b5aa19d666397a62a11f7ed7c64fa6bf096e83;hb=a983b2e80865eda767b4223934afa4f50983f48d;hp=513303f48fb45d3d8cb86b06eacd4ae0d77eba76;hpb=728cc74b3df1bfb78de1a2a42c3ca81fe6e89c89;p=jalview.git diff --git a/src/jalview/gui/SplitFrame.java b/src/jalview/gui/SplitFrame.java index 513303f..f9b5aa1 100644 --- a/src/jalview/gui/SplitFrame.java +++ b/src/jalview/gui/SplitFrame.java @@ -861,7 +861,7 @@ public class SplitFrame extends GSplitFrame implements SplitContainerI FeatureSettingsControllerGuiI featureSettings) { boolean showInternalFrame = false; - if (featureSettingsUI == null) + if (featureSettingsUI == null || featureSettingsPanels == null) { showInternalFrame = true; featureSettingsPanels = new JTabbedPane(); @@ -869,29 +869,7 @@ public class SplitFrame extends GSplitFrame implements SplitContainerI "Feature Settings for CDS and Protein Views"); featureSettingsPanels.setOpaque(true); featureSettingsUI.setContentPane(featureSettingsPanels); - JPanel dummyDNA = new JPanel(),dummyProtein=new JPanel(); - FocusListener fl1 = new FocusListener() - { - - @Override - public void focusLost(FocusEvent e) - { - // TODO Auto-generated method stub - - } - - @Override - public void focusGained(FocusEvent e) - { - int tab = featureSettingsPanels.getSelectedIndex(); - getAlignFrames().get(tab).showFeatureSettingsUI(); - } - }; - dummyDNA.addFocusListener(fl1); - dummyProtein.addFocusListener(fl1); - - featureSettingsPanels.addTab("CDS", dummyDNA); - featureSettingsPanels.addTab("Protein", dummyProtein); + createDummyTabs(); } if (featureSettingsPanels .indexOfTabComponent((Component) featureSettings) > -1) @@ -967,19 +945,103 @@ public class SplitFrame extends GSplitFrame implements SplitContainerI } } + /* + * for materialising feature settings for a tab when clicked on + */ + private FocusListener fl1 = new FocusListener() + { + + @Override + public void focusLost(FocusEvent e) + { + // TODO Auto-generated method stub + + } + + @Override + public void focusGained(FocusEvent e) + { + int tab = featureSettingsPanels.getSelectedIndex(); + getAlignFrames().get(tab).showFeatureSettingsUI(); + } + }; + + /** + * tab names for feature settings + */ + private String[] tabName = new String[] { + MessageManager.getString("label.CDS"), + MessageManager.getString("label.Protein") }; + + /** + * create placeholder tabs which materialise the feature settings for a given + * view. Also reinitialises any tabs containing stale feature settings + */ + private void createDummyTabs() + { + for (int tabIndex = 0; tabIndex < 2; tabIndex++) + { + JPanel dummyTab = new JPanel(); + dummyTab.addFocusListener(fl1); + featureSettingsPanels.addTab(tabName[tabIndex], dummyTab); + } + } + + private void replaceWithDummyTab(FeatureSettingsControllerI toClose) + { + Component dummyTab = null; + for (int tabIndex = 0; tabIndex < 2; tabIndex++) + { + if (featureSettingsPanels.getTabCount() > tabIndex) + { + dummyTab = featureSettingsPanels.getTabComponentAt(tabIndex); + if (dummyTab instanceof FeatureSettingsControllerGuiI + && !dummyTab.isVisible()) + { + featureSettingsPanels.removeTabAt(tabIndex); + // close the feature Settings tab + ((FeatureSettingsControllerGuiI) dummyTab) + .featureSettings_isClosed(); + // create a dummy tab in its place + dummyTab = new JPanel(); + dummyTab.addFocusListener(fl1); + featureSettingsPanels.insertTab(tabName[tabIndex], null, dummyTab, + MessageManager.formatMessage( + "label.sequence_feature_settings_for", + tabName[tabIndex]), + tabIndex); + } + } + } + } + @Override public void closeFeatureSettings( - FeatureSettingsControllerI featureSettings) + FeatureSettingsControllerI featureSettings, + boolean closeContainingFrame) { if (featureSettingsUI != null) { - try + if (closeContainingFrame) { - featureSettingsUI.setClosed(true); - } catch (Exception x) + try + { + featureSettingsUI.setClosed(true); + } catch (Exception x) + { + } + featureSettingsUI = null; + } + else { + replaceWithDummyTab(featureSettings); } - featureSettingsUI = null; } } + + @Override + public boolean isFeatureSettingsOpen() + { + return featureSettingsUI != null && !featureSettingsUI.isClosed(); + } } \ No newline at end of file