Formatting
[jalview.git] / src / jalview / io / JalviewFileChooser.java
1 /*\r
2  * Jalview - A Sequence Alignment Editor and Viewer\r
3  * Copyright (C) 2007 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle\r
4  *\r
5  * This program is free software; you can redistribute it and/or\r
6  * modify it under the terms of the GNU General Public License\r
7  * as published by the Free Software Foundation; either version 2\r
8  * of the License, or (at your option) any later version.\r
9  *\r
10  * This program is distributed in the hope that it will be useful,\r
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
13  * GNU General Public License for more details.\r
14  *\r
15  * You should have received a copy of the GNU General Public License\r
16  * along with this program; if not, write to the Free Software\r
17  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA\r
18  */\r
19 \r
20 //////////////////////////////////////////////////////////////////\r
21 package jalview.io;\r
22 \r
23 import java.io.*;\r
24 import java.util.*;\r
25 \r
26 import java.awt.*;\r
27 import java.awt.event.*;\r
28 import javax.swing.*;\r
29 \r
30 public class JalviewFileChooser\r
31     extends JFileChooser\r
32 {\r
33 \r
34   public JalviewFileChooser(String dir)\r
35   {\r
36     super(dir);\r
37     setAccessory(new RecentlyOpened());\r
38   }\r
39 \r
40   public JalviewFileChooser(String dir,\r
41                             String[] suffix,\r
42                             String[] desc,\r
43                             String selected,\r
44                             boolean selectAll)\r
45   {\r
46     super(dir);\r
47     init(suffix, desc, selected, selectAll);\r
48   }\r
49 \r
50   public JalviewFileChooser(String dir,\r
51                             String[] suffix,\r
52                             String[] desc,\r
53                             String selected)\r
54   {\r
55     super(dir);\r
56     init(suffix, desc, selected, true);\r
57   }\r
58 \r
59   void init(String[] suffix,\r
60             String[] desc,\r
61             String selected,\r
62             boolean selectAll)\r
63   {\r
64 \r
65     JalviewFileFilter chosen = null;\r
66 \r
67     //SelectAllFilter needs to be set first before adding further\r
68     //file filters to fix bug on Mac OSX\r
69     setAcceptAllFileFilterUsed(selectAll);\r
70 \r
71     for (int i = 0; i < suffix.length; i++)\r
72     {\r
73       JalviewFileFilter jvf = new JalviewFileFilter(suffix[i], desc[i]);\r
74       addChoosableFileFilter(jvf);\r
75 \r
76       if ( (selected != null) && selected.equalsIgnoreCase(desc[i]))\r
77       {\r
78         chosen = jvf;\r
79       }\r
80     }\r
81 \r
82     if (chosen != null)\r
83     {\r
84       setFileFilter(chosen);\r
85     }\r
86 \r
87     setAccessory(new RecentlyOpened());\r
88   }\r
89 \r
90   public void setFileFilter(javax.swing.filechooser.FileFilter filter)\r
91   {\r
92     super.setFileFilter(filter);\r
93 \r
94     try\r
95     {\r
96       if (getUI() instanceof javax.swing.plaf.basic.BasicFileChooserUI)\r
97       {\r
98         final javax.swing.plaf.basic.BasicFileChooserUI ui = (javax.swing.plaf.\r
99             basic.BasicFileChooserUI) getUI();\r
100         final String name = ui.getFileName().trim();\r
101 \r
102         if ( (name == null) || (name.length() == 0))\r
103         {\r
104           return;\r
105         }\r
106 \r
107         EventQueue.invokeLater(new Thread()\r
108         {\r
109           public void run()\r
110           {\r
111             String currentName = ui.getFileName();\r
112             if ( (currentName == null) || (currentName.length() == 0))\r
113             {\r
114               ui.setFileName(name);\r
115             }\r
116           }\r
117         });\r
118       }\r
119     }\r
120     catch (Exception ex)\r
121     {\r
122       ex.printStackTrace();\r
123       // Some platforms do not have BasicFileChooserUI\r
124     }\r
125   }\r
126 \r
127   public String getSelectedFormat()\r
128   {\r
129     if (getFileFilter() == null)\r
130     {\r
131       return null;\r
132     }\r
133 \r
134     String format = getFileFilter().getDescription();\r
135 \r
136     if (format.toUpperCase().startsWith("JALVIEW"))\r
137     {\r
138       format = "Jalview";\r
139     }\r
140     else if (format.toUpperCase().startsWith("FASTA"))\r
141     {\r
142       format = "FASTA";\r
143     }\r
144     else if (format.toUpperCase().startsWith("MSF"))\r
145     {\r
146       format = "MSF";\r
147     }\r
148     else if (format.toUpperCase().startsWith("CLUSTAL"))\r
149     {\r
150       format = "CLUSTAL";\r
151     }\r
152     else if (format.toUpperCase().startsWith("BLC"))\r
153     {\r
154       format = "BLC";\r
155     }\r
156     else if (format.toUpperCase().startsWith("PIR"))\r
157     {\r
158       format = "PIR";\r
159     }\r
160     else if (format.toUpperCase().startsWith("PFAM"))\r
161     {\r
162       format = "PFAM";\r
163     }\r
164 \r
165     return format;\r
166   }\r
167 \r
168   public int showSaveDialog(Component parent)\r
169       throws HeadlessException\r
170   {\r
171     this.setAccessory(null);\r
172 \r
173     setDialogType(SAVE_DIALOG);\r
174 \r
175     int ret = showDialog(parent, "Save");\r
176 \r
177     if (getFileFilter() instanceof JalviewFileFilter)\r
178     {\r
179       JalviewFileFilter jvf = (JalviewFileFilter) getFileFilter();\r
180 \r
181       if (!jvf.accept(getSelectedFile()))\r
182       {\r
183         String withExtension = getSelectedFile() + "." +\r
184             jvf.getAcceptableExtension();\r
185         setSelectedFile(new File(withExtension));\r
186       }\r
187     }\r
188 \r
189     if ( (ret == JalviewFileChooser.APPROVE_OPTION) &&\r
190         getSelectedFile().exists())\r
191     {\r
192       int confirm = JOptionPane.showConfirmDialog(parent,\r
193                                                   "Overwrite existing file?",\r
194                                                   "File exists",\r
195                                                   JOptionPane.YES_NO_OPTION);\r
196 \r
197       if (confirm != JOptionPane.YES_OPTION)\r
198       {\r
199         ret = JalviewFileChooser.CANCEL_OPTION;\r
200       }\r
201     }\r
202 \r
203     return ret;\r
204   }\r
205 \r
206   void recentListSelectionChanged(String selection)\r
207   {\r
208     setSelectedFile(null);\r
209 \r
210     File file = new File(selection);\r
211     if (getFileFilter() instanceof JalviewFileFilter)\r
212     {\r
213       JalviewFileFilter jvf = (JalviewFileFilter)this.getFileFilter();\r
214 \r
215       if (!jvf.accept(file))\r
216       {\r
217         setFileFilter(getChoosableFileFilters()[0]);\r
218       }\r
219     }\r
220 \r
221     setSelectedFile(file);\r
222   }\r
223 \r
224   class RecentlyOpened\r
225       extends JPanel\r
226   {\r
227     JList list;\r
228     public RecentlyOpened()\r
229     {\r
230       String historyItems = jalview.bin.Cache.getProperty("RECENT_FILE");\r
231       StringTokenizer st;\r
232       Vector recent = new Vector();\r
233 \r
234       if (historyItems != null)\r
235       {\r
236         st = new StringTokenizer(historyItems, "\t");\r
237 \r
238         while (st.hasMoreTokens())\r
239         {\r
240           recent.addElement(st.nextElement());\r
241         }\r
242       }\r
243 \r
244       list = new JList(recent);\r
245 \r
246       DefaultListCellRenderer dlcr = new DefaultListCellRenderer();\r
247       dlcr.setHorizontalAlignment(DefaultListCellRenderer.RIGHT);\r
248       list.setCellRenderer(dlcr);\r
249 \r
250       list.addMouseListener(new MouseAdapter()\r
251       {\r
252         public void mousePressed(MouseEvent evt)\r
253         {\r
254           recentListSelectionChanged(list.getSelectedValue().toString());\r
255         }\r
256       });\r
257 \r
258       this.setBorder(new javax.swing.border.TitledBorder("Recently Opened"));\r
259 \r
260       final JScrollPane scroller = new JScrollPane(list);\r
261       scroller.setPreferredSize(new Dimension(130, 200));\r
262       this.add(scroller);\r
263 \r
264       javax.swing.SwingUtilities.invokeLater(new Runnable()\r
265       {\r
266         public void run()\r
267         {\r
268           scroller.getHorizontalScrollBar().setValue(\r
269               scroller.getHorizontalScrollBar().getMaximum());\r
270         }\r
271       });\r
272 \r
273     }\r
274 \r
275   }\r
276 }\r