source: AE/installer2/src/net/oni2/aeinstaller/gui/MainWin.java@ 660

Last change on this file since 660 was 660, checked in by alloc, 12 years ago

AEI2 0.99k:

  • Added mod string filter
  • Made jump-to-mod by key-press cycle through mods if pressed multiple times
File size: 25.6 KB
Line 
1package net.oni2.aeinstaller.gui;
2
3import java.awt.BorderLayout;
4import java.awt.Desktop;
5import java.awt.GridLayout;
6import java.awt.event.ActionEvent;
7import java.awt.event.ItemEvent;
8import java.awt.event.ItemListener;
9import java.awt.event.KeyAdapter;
10import java.awt.event.KeyEvent;
11import java.io.File;
12import java.net.URL;
13import java.util.Date;
14import java.util.HashMap;
15import java.util.HashSet;
16import java.util.ResourceBundle;
17import java.util.TreeMap;
18import java.util.TreeSet;
19import java.util.Vector;
20
21import javax.swing.AbstractAction;
22import javax.swing.Icon;
23import javax.swing.ImageIcon;
24import javax.swing.JButton;
25import javax.swing.JCheckBox;
26import javax.swing.JComboBox;
27import javax.swing.JFileChooser;
28import javax.swing.JFrame;
29import javax.swing.JLabel;
30import javax.swing.JMenu;
31import javax.swing.JMenuItem;
32import javax.swing.JOptionPane;
33import javax.swing.JPanel;
34import javax.swing.JRadioButton;
35import javax.swing.JScrollPane;
36import javax.swing.JSplitPane;
37import javax.swing.JTextField;
38import javax.swing.SwingUtilities;
39import javax.swing.ToolTipManager;
40import javax.swing.filechooser.FileFilter;
41
42import net.oni2.aeinstaller.AEInstaller2;
43import net.oni2.aeinstaller.backend.AppExecution;
44import net.oni2.aeinstaller.backend.Paths;
45import net.oni2.aeinstaller.backend.Settings;
46import net.oni2.aeinstaller.backend.Settings.Platform;
47import net.oni2.aeinstaller.backend.SizeFormatter;
48import net.oni2.aeinstaller.backend.depot.DepotManager;
49import net.oni2.aeinstaller.backend.oni.InstallProgressListener;
50import net.oni2.aeinstaller.backend.oni.Installer;
51import net.oni2.aeinstaller.backend.oni.OniSplit;
52import net.oni2.aeinstaller.backend.packages.Package;
53import net.oni2.aeinstaller.backend.packages.PackageManager;
54import net.oni2.aeinstaller.backend.packages.Type;
55import net.oni2.aeinstaller.backend.packages.download.ModDownloader;
56import net.oni2.aeinstaller.backend.packages.download.ModDownloader.State;
57import net.oni2.aeinstaller.backend.packages.download.ModDownloaderListener;
58import net.oni2.aeinstaller.gui.about.AboutDialog;
59import net.oni2.aeinstaller.gui.corepackages.CorePackagesDialog;
60import net.oni2.aeinstaller.gui.downloadwindow.Downloader;
61import net.oni2.aeinstaller.gui.modtable.DownloadSizeListener;
62import net.oni2.aeinstaller.gui.modtable.EApplyFilterTo;
63import net.oni2.aeinstaller.gui.modtable.ModSelectionListener;
64import net.oni2.aeinstaller.gui.modtable.ModTable;
65import net.oni2.aeinstaller.gui.modtable.ModTable.ETableContentType;
66import net.oni2.aeinstaller.gui.packageinfobox.PackageInfoBox;
67import net.oni2.aeinstaller.gui.settings.SettingsDialog;
68import net.oni2.aeinstaller.gui.toolmanager.ToolManager;
69
70import org.javabuilders.BuildResult;
71import org.javabuilders.annotations.DoInBackground;
72import org.javabuilders.event.BackgroundEvent;
73import org.javabuilders.swing.SwingJavaBuilder;
74import org.simplericity.macify.eawt.ApplicationEvent;
75import org.simplericity.macify.eawt.ApplicationListener;
76
77/**
78 * @author Christian Illy
79 */
80public class MainWin extends JFrame implements ApplicationListener,
81 DownloadSizeListener, ModSelectionListener {
82 private static final long serialVersionUID = -4027395051382659650L;
83
84 private ResourceBundle bundle = ResourceBundle
85 .getBundle("net.oni2.aeinstaller.localization."
86 + getClass().getSimpleName());
87 @SuppressWarnings("unused")
88 private BuildResult result = SwingJavaBuilder.build(this, bundle);
89
90 private JMenu mainMenu;
91 private JMenu toolsMenu;
92 private Vector<JMenuItem> toolsMenuItems = new Vector<JMenuItem>();
93
94 private JSplitPane contents;
95
96 private JComboBox cmbModTypes;
97 private JRadioButton radAll;
98 private JRadioButton radOnline;
99 private JRadioButton radLocal;
100 private JTextField txtShowFilter;
101 private JComboBox cmbShowFilterTo;
102 private JScrollPane scrollMods;
103 private ModTable tblMods;
104 private JLabel lblDownloadSizeVal;
105
106 private PackageInfoBox pkgInfo;
107
108 private JButton btnInstall;
109
110 private TreeSet<Package> execCoreUpdates = new TreeSet<Package>();
111 private TreeSet<Package> execUpdates = null;
112
113 private enum EInstallState {
114 DONE,
115 READY,
116 ABORTED,
117 OFFLINE,
118 INCOMPATIBLE,
119 CHECKING
120 };
121
122 private EInstallState installState = EInstallState.DONE;
123 private TreeSet<Package> installMods = null;
124 private TreeSet<Package> installDeps = null;
125
126 /**
127 * Constructor of main window.
128 */
129 public MainWin() {
130 this.setTitle(SwingJavaBuilder.getConfig().getResource("appname")
131 + " - v"
132 + SwingJavaBuilder.getConfig().getResource("appversion"));
133
134 tblMods = new ModTable(ETableContentType.MODS);
135 tblMods.setVisible(false);
136 scrollMods.setViewportView(tblMods);
137
138 contents.setDividerLocation(550);
139 contents.setResizeWeight(0.4);
140
141 if (Settings.getPlatform() == Platform.MACOS) {
142 mainMenu.setVisible(false);
143 }
144
145 ToolTipManager.sharedInstance().setInitialDelay(250);
146
147 getRootPane().setDefaultButton(btnInstall);
148 lblDownloadSizeVal.setText(SizeFormatter.format(0, 2));
149 radAll.setSelected(true);
150
151 for (EApplyFilterTo f : EApplyFilterTo.values()) {
152 cmbShowFilterTo.addItem(f);
153 }
154 txtShowFilter.addKeyListener(new KeyAdapter() {
155 @Override
156 public void keyReleased(KeyEvent e) {
157 super.keyReleased(e);
158 updateTableFilter();
159 }
160 });
161
162 tblMods.addModSelectionListener(this);
163 tblMods.addDownloadSizeListener(this);
164 }
165
166 private void initModTypeBox() {
167 cmbModTypes.removeAllItems();
168
169 TreeMap<String, Type> types = new TreeMap<String, Type>();
170 for (Type t : PackageManager.getInstance().getTypesWithContent()) {
171 types.put(t.getName(), t);
172 }
173 cmbModTypes.addItem("-All-");
174 for (Type t : types.values()) {
175 cmbModTypes.addItem(t);
176 }
177 cmbModTypes.setSelectedIndex(0);
178 }
179
180 private void exit() {
181 dispose();
182 System.exit(0);
183 }
184
185 private void saveLocalData() {
186 Settings.getInstance().serializeToFile();
187 }
188
189 @DoInBackground(progressMessage = "updateDepot.title", cancelable = false, indeterminateProgress = false)
190 private void execDepotUpdate(final BackgroundEvent evt) {
191 if (!Settings.getInstance().isOfflineMode()
192 && !Settings.getInstance().isNoCacheUpdateMode()) {
193 long start = new Date().getTime();
194
195 try {
196 DepotManager.getInstance().updateInformation(false);
197 } catch (Exception e) {
198 e.printStackTrace();
199 }
200
201 System.out.println("Took: " + (new Date().getTime() - start)
202 + " msec");
203 }
204
205 PackageManager.getInstance().init();
206 tblMods.reloadData();
207 initModTypeBox();
208
209 tblMods.setVisible(true);
210 }
211
212 @SuppressWarnings("unused")
213 private void checkUpdates(Object evtSource) {
214 if ((evtSource != this)
215 || Settings.getInstance().get("notifyupdates", true)) {
216 if (Settings.getInstance().isOfflineMode()) {
217 if (evtSource != this) {
218 JOptionPane.showMessageDialog(
219 this,
220 SwingJavaBuilder.getConfig().getResource(
221 "offlineMode.text"),
222 SwingJavaBuilder.getConfig().getResource(
223 "offlineMode.title"),
224 JOptionPane.WARNING_MESSAGE);
225 }
226 } else {
227 TreeSet<Package> mods = PackageManager.getInstance()
228 .getUpdatableMods();
229 TreeSet<Package> tools = PackageManager.getInstance()
230 .getUpdatableTools();
231 int size = 0;
232 JPanel panPackages = new JPanel(new GridLayout(0, 1));
233 execUpdates = new TreeSet<Package>();
234 execUpdates.addAll(mods);
235 execUpdates.addAll(tools);
236 for (final Package m : mods) {
237 size += m.getZipSize();
238 JCheckBox check = new JCheckBox("Mod: " + m.getName());
239 check.setSelected(true);
240 check.addItemListener(new ItemListener() {
241 @Override
242 public void itemStateChanged(ItemEvent e) {
243 if (e.getStateChange() == ItemEvent.SELECTED)
244 execUpdates.add(m);
245 else
246 execUpdates.remove(m);
247 }
248 });
249 panPackages.add(check);
250 }
251 for (final Package m : tools) {
252 size += m.getZipSize();
253 JCheckBox check = new JCheckBox("Tool: " + m.getName());
254 check.setSelected(true);
255 panPackages.add(check);
256 }
257 if (size > 0) {
258 // Build info dialog content
259 JPanel packages = new JPanel(new BorderLayout(0, 7));
260 JLabel lblIntro = new JLabel("<html>"
261 + bundle.getString("updatesAvailable.text")
262 + "</html>");
263 JLabel lblSize = new JLabel("<html>"
264 + String.format(bundle
265 .getString("updatesAvailableSize.text"),
266 SizeFormatter.format(size, 3)) + "</html>");
267 packages.add(lblIntro, BorderLayout.NORTH);
268 packages.add(panPackages, BorderLayout.CENTER);
269 packages.add(lblSize, BorderLayout.SOUTH);
270
271 JPanel pan = new JPanel(new BorderLayout(0, 25));
272 pan.add(packages, BorderLayout.CENTER);
273 JCheckBox checkFutureUpdates = new JCheckBox(
274 bundle.getString("checkOnStartup.text"));
275 checkFutureUpdates.setSelected(Settings.getInstance().get(
276 "notifyupdates", true));
277 checkFutureUpdates.addItemListener(new ItemListener() {
278 @Override
279 public void itemStateChanged(ItemEvent evt) {
280 Settings.getInstance().put("notifyupdates",
281 evt.getStateChange() == ItemEvent.SELECTED);
282 }
283 });
284 pan.add(checkFutureUpdates, BorderLayout.SOUTH);
285
286 // Show dialog
287 int res = JOptionPane.showConfirmDialog(this, pan,
288 bundle.getString("updatesAvailable.title"),
289 JOptionPane.YES_NO_OPTION,
290 JOptionPane.QUESTION_MESSAGE);
291 if (res == JOptionPane.NO_OPTION) {
292 execUpdates = null;
293 }
294 } else {
295 if (evtSource != this) {
296 JOptionPane.showMessageDialog(this,
297 bundle.getString("updatesNotAvailable.text"),
298 bundle.getString("updatesNotAvailable.title"),
299 JOptionPane.INFORMATION_MESSAGE);
300 }
301 }
302 }
303 }
304 }
305
306 @SuppressWarnings("unused")
307 private void doUpdate() {
308 if (execUpdates != null && execUpdates.size() > 0) {
309 Downloader dl = new Downloader(execUpdates, null);
310 try {
311 dl.setVisible(true);
312 if (dl.isFinished()) {
313 TreeSet<Integer> installed = Installer.getInstalledTools();
314 TreeSet<Package> tools = new TreeSet<Package>();
315 for (Package m : execUpdates)
316 if (m.isTool()
317 && installed.contains(m.getPackageNumber()))
318 tools.add(m);
319 if (tools.size() > 0) {
320 Installer.installTools(tools);
321 }
322 }
323 } finally {
324 dl.dispose();
325 }
326 }
327 execUpdates = null;
328 }
329
330 @SuppressWarnings("unused")
331 private void focus() {
332 SwingUtilities.invokeLater(new Runnable() {
333
334 @Override
335 public void run() {
336 toFront();
337 repaint();
338 }
339 });
340
341 }
342
343 @SuppressWarnings("unused")
344 private void showCorePackagesDialog() {
345 new CorePackagesDialog().setVisible(true);
346 }
347
348 private void showSettings() {
349 new SettingsDialog().setVisible(true);
350 }
351
352 private void showAbout() {
353 new AboutDialog().setVisible(true);
354 }
355
356 private JFileChooser getConfigOpenSaveDialog(boolean save) {
357 JFileChooser fc = new JFileChooser();
358 fc.setCurrentDirectory(Paths.getEditionBasePath());
359 if (save)
360 fc.setDialogType(JFileChooser.SAVE_DIALOG);
361 else
362 fc.setDialogType(JFileChooser.OPEN_DIALOG);
363 fc.setFileSelectionMode(JFileChooser.FILES_ONLY);
364 fc.setFileFilter(new FileFilter() {
365 @Override
366 public String getDescription() {
367 return "XML files";
368 }
369
370 @Override
371 public boolean accept(File arg0) {
372 return (arg0.isDirectory())
373 || (arg0.getName().toLowerCase().endsWith(".xml"));
374 }
375 });
376 fc.setMultiSelectionEnabled(false);
377 return fc;
378 }
379
380 @SuppressWarnings("unused")
381 private void loadConfig() {
382 JFileChooser fc = getConfigOpenSaveDialog(false);
383 int res = fc.showOpenDialog(this);
384 if (res == JFileChooser.APPROVE_OPTION) {
385 if (fc.getSelectedFile().exists())
386 tblMods.reloadSelection(fc.getSelectedFile());
387 }
388 }
389
390 @SuppressWarnings("unused")
391 private void saveConfig() {
392 JFileChooser fc = getConfigOpenSaveDialog(true);
393 int res = fc.showSaveDialog(this);
394 if (res == JFileChooser.APPROVE_OPTION) {
395 File f = fc.getSelectedFile();
396 if (!f.getName().endsWith(".xml"))
397 f = new File(f.getParentFile(), f.getName() + ".xml");
398 PackageManager.getInstance().saveModSelection(f,
399 tblMods.getSelectedMods());
400 }
401 }
402
403 @DoInBackground(progressMessage = "initializingEdition.title", cancelable = false, indeterminateProgress = false)
404 private void reglobalize(final BackgroundEvent evt) {
405 Installer.initializeEdition(new InstallProgressListener() {
406 @Override
407 public void installProgressUpdate(int done, int total, String step) {
408 evt.setProgressEnd(total);
409 evt.setProgressValue(done);
410 evt.setProgressMessage(step);
411 }
412 });
413 }
414
415 @SuppressWarnings("unused")
416 private void tools() {
417 new ToolManager().setVisible(true);
418 }
419
420 @SuppressWarnings("unused")
421 private void refreshToolsMenu() {
422 for (JMenuItem i : toolsMenuItems) {
423 toolsMenu.remove(i);
424 }
425 toolsMenuItems.clear();
426 for (Package m : PackageManager.getInstance().getInstalledTools()) {
427 File exe = m.getExeFile();
428 if (exe != null && exe.exists()) {
429 JMenuItem item = new JMenuItem();
430 final Vector<String> params = new Vector<String>();
431 if (exe.getName().toLowerCase().endsWith(".jar")) {
432 File jre = null;
433 if (Settings.getPlatform() == Platform.WIN)
434 jre = new File(System.getProperties().getProperty(
435 "java.home"), "bin/javaw.exe");
436 else
437 jre = new File(System.getProperties().getProperty(
438 "java.home"), "bin/java");
439 params.add(jre.getPath());
440 params.add("-jar");
441 }
442 params.add(exe.getPath());
443 final File wd = m.getWorkingDir();
444 Icon ico = null;
445 if (m.getIconFile() != null && m.getIconFile().exists()) {
446 ico = new ImageIcon(m.getIconFile().getPath());
447 } else {
448 URL icon = AEInstaller2.class
449 .getResource("images/transparent.png");
450 ico = new ImageIcon(icon);
451 }
452 item.setAction(new AbstractAction(m.getName(), ico) {
453 private static final long serialVersionUID = 1L;
454
455 @Override
456 public void actionPerformed(ActionEvent e) {
457 AppExecution.execute(params, wd);
458 }
459 });
460 toolsMenuItems.add(item);
461 toolsMenu.add(item);
462 }
463 }
464 }
465
466 private void revertSelection() {
467 tblMods.revertSelection();
468 }
469
470 @SuppressWarnings("unused")
471 private void unSelectAll() {
472 tblMods.unSelectAll();
473 }
474
475 @DoInBackground(progressMessage = "checkCorePackages.title", cancelable = false, indeterminateProgress = false)
476 private void checkCorePackages(final BackgroundEvent evt) {
477 if (!Settings.getInstance().isOfflineMode()) {
478 for (Package m : PackageManager.getInstance().getCoreTools()) {
479 if (m.isNewerAvailable()) {
480 execCoreUpdates.add(m);
481 }
482 }
483 for (Package m : PackageManager.getInstance().getCoreMods()) {
484 if (m.isNewerAvailable()) {
485 execCoreUpdates.add(m);
486 }
487 }
488 if (execCoreUpdates.size() > 0) {
489 ModDownloader m = new ModDownloader(execCoreUpdates,
490 new ModDownloaderListener() {
491 @Override
492 public void updateStatus(ModDownloader source,
493 Package currentDownload, State state,
494 int filesDown, int filesTotal,
495 int bytesDown, int bytesTotal,
496 int duration, int remaining, int speed) {
497 evt.setProgressEnd(filesTotal);
498 evt.setProgressValue(filesDown);
499 }
500 });
501 while (!m.isFinished()) {
502 try {
503 Thread.sleep(10);
504 } catch (InterruptedException e) {
505 e.printStackTrace();
506 }
507 }
508 }
509 evt.setProgressMessage(bundle.getString("coreToolsInstall.title"));
510 Installer.installTools(PackageManager.getInstance().getCoreTools());
511 }
512 }
513
514 @SuppressWarnings("unused")
515 private void infoCorePackages() {
516 if (execCoreUpdates.size() > 0) {
517 String packages = "";
518 for (Package m : execCoreUpdates) {
519 packages += String.format("\n - %s (%s)", m.getName(),
520 m.getVersion());
521 }
522 JOptionPane.showMessageDialog(this, String.format(
523 bundle.getString("corePackagesUpdated.text"), packages),
524 bundle.getString("corePackagesUpdated.title"),
525 JOptionPane.INFORMATION_MESSAGE);
526 }
527 }
528
529 @SuppressWarnings("unused")
530 private void install() {
531 TreeSet<Package> mods = new TreeSet<Package>();
532 mods.addAll(PackageManager.getInstance().getCoreMods());
533 mods.addAll(tblMods.getSelectedMods());
534
535 installDeps = new TreeSet<Package>();
536
537 installState = EInstallState.CHECKING;
538
539 while (installState == EInstallState.CHECKING) {
540 TreeSet<Package> toDownload = new TreeSet<Package>();
541 for (Package m : mods) {
542 if (!m.isLocalAvailable())
543 toDownload.add(m);
544 }
545 if (toDownload.size() > 0 && Settings.getInstance().isOfflineMode()) {
546 installState = EInstallState.OFFLINE;
547 break;
548 }
549 if (toDownload.size() > 0) {
550 Downloader dl = new Downloader(toDownload, installDeps);
551 try {
552 dl.setVisible(true);
553 if (!dl.isFinished()) {
554 installState = EInstallState.ABORTED;
555 break;
556 }
557 } finally {
558 dl.dispose();
559 }
560 }
561 HashMap<Package, HashSet<Package>> dependencies = PackageManager
562 .getInstance().checkDependencies(mods);
563 if (dependencies.size() > 0) {
564 for (HashSet<Package> hm : dependencies.values()) {
565 installDeps.addAll(hm);
566 }
567
568 if (!Settings.getInstance()
569 .get("notifyDepsAfterInstall", false)) {
570 int size = 0;
571 String depsLocalString = "";
572 String depsDownloadString = "";
573 for (Package m : dependencies.keySet()) {
574 for (Package mDep : dependencies.get(m)) {
575 if (!mods.contains(mDep)) {
576 mods.add(mDep);
577 if (!mDep.isLocalAvailable()) {
578 size += mDep.getZipSize();
579 if (depsDownloadString.length() > 0)
580 depsDownloadString += "\n";
581 depsDownloadString += " - "
582 + mDep.getName();
583 } else {
584 if (depsLocalString.length() > 0)
585 depsLocalString += "\n";
586 depsLocalString += " - " + mDep.getName();
587 }
588 }
589 }
590 }
591 if (depsLocalString.length() == 0)
592 depsLocalString = bundle
593 .getString("installDependencies.none");
594 if (depsDownloadString.length() == 0)
595 depsDownloadString = bundle
596 .getString("installDependencies.none");
597
598 int res = JOptionPane.showConfirmDialog(this, String
599 .format(bundle
600 .getString("installDependencies.text"),
601 depsLocalString, depsDownloadString,
602 SizeFormatter.format(size, 3)), bundle
603 .getString("installDependencies.title"),
604 JOptionPane.YES_NO_OPTION,
605 JOptionPane.INFORMATION_MESSAGE);
606 if (res == JOptionPane.NO_OPTION) {
607 installState = EInstallState.ABORTED;
608 break;
609 }
610 }
611 } else {
612 HashMap<Package, HashSet<Package>> incompatibilities = PackageManager
613 .getInstance().checkIncompabitilites(mods);
614 if (incompatibilities.size() > 0) {
615 installState = EInstallState.INCOMPATIBLE;
616
617 String incompatString = "";
618 for (Package m : incompatibilities.keySet()) {
619 if (incompatString.length() > 0)
620 incompatString += "\n";
621 incompatString += m.getName() + ": ";
622 String confMods = "";
623 for (Package mConf : incompatibilities.get(m)) {
624 if (confMods.length() > 0)
625 confMods += ", ";
626 confMods += mConf.getName();
627 }
628 incompatString += confMods;
629 }
630
631 JOptionPane.showMessageDialog(this, String.format(
632 bundle.getString("installIncompatibilities.text"),
633 incompatString), bundle
634 .getString("installIncompatibilities.title"),
635 JOptionPane.ERROR_MESSAGE);
636 break;
637 } else {
638 installState = EInstallState.READY;
639 }
640 }
641 }
642
643 if (installState == EInstallState.READY) {
644 installMods = new TreeSet<Package>();
645 TreeSet<Package> actuallyTools = new TreeSet<Package>();
646
647 for (Package m : mods) {
648 if (m.isTool())
649 actuallyTools.add(m);
650 else
651 installMods.add(m);
652 }
653
654 if (actuallyTools.size() > 0) {
655 Installer.installTools(actuallyTools);
656 }
657 }
658
659 }
660
661 @DoInBackground(progressMessage = "installing.title", cancelable = false, indeterminateProgress = false)
662 private void installExec(final BackgroundEvent evt) {
663 if (installState == EInstallState.READY) {
664 Installer.install(installMods, new InstallProgressListener() {
665 @Override
666 public void installProgressUpdate(int done, int total,
667 String step) {
668 evt.setProgressEnd(total);
669 evt.setProgressValue(done);
670 evt.setProgressMessage(step);
671 }
672 });
673 installState = EInstallState.DONE;
674 }
675 installMods = null;
676 }
677
678 @SuppressWarnings("unused")
679 private void installDone() {
680 PackageManager.getInstance().updateInstalledMods();
681 switch (installState) {
682 case DONE:
683 revertSelection();
684 if (installDeps.size() > 0
685 && Settings.getInstance().get("notifyDepsAfterInstall",
686 false)) {
687 String installedDeps = "";
688 for (Package m : installDeps) {
689 if (installedDeps.length() > 0)
690 installedDeps += "\n";
691 installedDeps += " - " + m.getName();
692 }
693 JOptionPane.showMessageDialog(this, String.format(
694 bundle.getString("installDoneDeps.text"),
695 installedDeps), bundle
696 .getString("installDone.title"),
697 JOptionPane.INFORMATION_MESSAGE);
698 } else {
699 JOptionPane.showMessageDialog(this,
700 bundle.getString("installDone.text"),
701 bundle.getString("installDone.title"),
702 JOptionPane.INFORMATION_MESSAGE);
703 }
704 break;
705 case OFFLINE:
706 JOptionPane.showMessageDialog(
707 this,
708 SwingJavaBuilder.getConfig().getResource(
709 "offlineMode.text"),
710 SwingJavaBuilder.getConfig().getResource(
711 "offlineMode.title"),
712 JOptionPane.WARNING_MESSAGE);
713 break;
714 default:
715 break;
716 }
717 installDeps = null;
718 }
719
720 @Override
721 public void modSelectionChanged(ModTable source, Package m) {
722 pkgInfo.updateInfo(m);
723 }
724
725 private void updateTableFilter() {
726 Object o = cmbModTypes.getSelectedItem();
727 Type t = null;
728 if (o instanceof Type)
729 t = (Type) o;
730 int downloadState = 0;
731 if (radOnline.isSelected())
732 downloadState = 1;
733 if (radLocal.isSelected())
734 downloadState = 2;
735 tblMods.setFilter(t, downloadState, txtShowFilter.getText(),
736 (EApplyFilterTo) cmbShowFilterTo.getSelectedItem());
737 }
738
739 @Override
740 public void downloadSizeChanged(int newSize) {
741 lblDownloadSizeVal.setText(SizeFormatter.format(newSize, 2));
742 }
743
744 @SuppressWarnings("unused")
745 private void checkInitialize() {
746 if (!Installer.isEditionInitialized()) {
747 if (!OniSplit.isOniSplitInstalled()) {
748 JOptionPane.showMessageDialog(this,
749 bundle.getString("noOniSplit.text"),
750 bundle.getString("noOniSplit.title"),
751 JOptionPane.ERROR_MESSAGE);
752 exit();
753 } else {
754 int res = JOptionPane
755 .showConfirmDialog(this,
756 bundle.getString("askInitialize.text"),
757 bundle.getString("askInitialize.title"),
758 JOptionPane.YES_NO_OPTION,
759 JOptionPane.QUESTION_MESSAGE);
760 if (res == JOptionPane.NO_OPTION) {
761 saveLocalData();
762 exit();
763 }
764 }
765 }
766 }
767
768 @DoInBackground(progressMessage = "initializingEdition.title", cancelable = false, indeterminateProgress = false)
769 private void initialize(final BackgroundEvent evt) {
770 if (!Installer.isEditionInitialized()) {
771 Installer.initializeEdition(new InstallProgressListener() {
772 @Override
773 public void installProgressUpdate(int done, int total,
774 String step) {
775 evt.setProgressEnd(total);
776 evt.setProgressValue(done);
777 evt.setProgressMessage(step);
778 }
779 });
780 }
781 }
782
783 private Vector<String> getBasicOniLaunchParams() {
784 Vector<String> params = new Vector<String>();
785 File exe = null;
786 switch (Settings.getPlatform()) {
787 case WIN:
788 exe = new File(Paths.getEditionBasePath(), "Oni.exe");
789 if (exe.exists())
790 params.add(exe.getPath());
791 break;
792 case MACOS:
793 exe = new File(Paths.getEditionBasePath(),
794 "Oni.app/Contents/MacOS/Oni");
795 if (exe.exists())
796 params.add(exe.getPath());
797 break;
798 case LINUX:
799 String wine = Settings.getWinePath();
800 exe = new File(Paths.getEditionBasePath(), "Oni.exe");
801 if (exe.exists()) {
802 if (wine != null) {
803 params.add(wine);
804 params.add(exe.getPath());
805 }
806 }
807 break;
808 default:
809 }
810 if (params.size() > 0) {
811 params.add("-debugfiles");
812 }
813 return params;
814 }
815
816 @SuppressWarnings("unused")
817 private void oniFull() {
818 Vector<String> params = getBasicOniLaunchParams();
819 if (params.size() > 0) {
820 AppExecution.execute(params, Paths.getEditionBasePath());
821 }
822 }
823
824 @SuppressWarnings("unused")
825 private void oniWin() {
826 Vector<String> params = getBasicOniLaunchParams();
827 if (params.size() > 0) {
828 params.add("-noswitch");
829 AppExecution.execute(params, Paths.getEditionBasePath());
830 }
831 }
832
833 @SuppressWarnings("unused")
834 private void openEditionFolder() {
835 try {
836 Desktop.getDesktop().open(Paths.getEditionBasePath());
837 } catch (Exception e) {
838 e.printStackTrace();
839 }
840 }
841
842 @Override
843 public void handleAbout(ApplicationEvent event) {
844 event.setHandled(true);
845 showAbout();
846 }
847
848 @Override
849 public void handleOpenApplication(ApplicationEvent event) {
850 }
851
852 @Override
853 public void handleOpenFile(ApplicationEvent event) {
854 }
855
856 @Override
857 public void handlePreferences(ApplicationEvent event) {
858 showSettings();
859 }
860
861 @Override
862 public void handlePrintFile(ApplicationEvent event) {
863 }
864
865 @Override
866 public void handleQuit(ApplicationEvent event) {
867 event.setHandled(true);
868 saveLocalData();
869 exit();
870 }
871
872 @Override
873 public void handleReOpenApplication(ApplicationEvent event) {
874 }
875
876}
Note: See TracBrowser for help on using the repository browser.