|
@@ -22,6 +22,7 @@
|
22
|
22
|
|
23
|
23
|
package com.dmdirc.addons.ui_swing.dialogs.updater;
|
24
|
24
|
|
|
25
|
+import com.dmdirc.addons.ui_swing.MainFrame;
|
25
|
26
|
import com.dmdirc.addons.ui_swing.UIUtilities;
|
26
|
27
|
import com.dmdirc.addons.ui_swing.components.LoggingSwingWorker;
|
27
|
28
|
import com.dmdirc.addons.ui_swing.components.PackingTable;
|
|
@@ -44,6 +45,8 @@ import java.awt.event.ActionListener;
|
44
|
45
|
import java.util.ArrayList;
|
45
|
46
|
import java.util.List;
|
46
|
47
|
|
|
48
|
+import javax.inject.Inject;
|
|
49
|
+import javax.inject.Provider;
|
47
|
50
|
import javax.swing.JButton;
|
48
|
51
|
import javax.swing.JScrollPane;
|
49
|
52
|
import javax.swing.JTable;
|
|
@@ -76,6 +79,8 @@ public class SwingUpdaterDialog extends StandardDialog implements
|
76
|
79
|
private UpdateComponentTableCellRenderer updateComponentRenderer;
|
77
|
80
|
/** Update.Status renderer. */
|
78
|
81
|
private UpdateStatusTableCellRenderer updateStatusRenderer;
|
|
82
|
+ /** Provider of restart dialogs. */
|
|
83
|
+ private final Provider<SwingRestartDialog> restartDialogProvider;
|
79
|
84
|
|
80
|
85
|
/**
|
81
|
86
|
* Creates a new instance of the updater dialog.
|
|
@@ -83,13 +88,19 @@ public class SwingUpdaterDialog extends StandardDialog implements
|
83
|
88
|
* @param updateManager The update manager to use for information
|
84
|
89
|
* @param dialogManager Dialog manager
|
85
|
90
|
* @param parentWindow Parent window
|
|
91
|
+ * @param restartDialogProvider Provider of restart dialogs.
|
86
|
92
|
*/
|
87
|
|
- public SwingUpdaterDialog(final CachingUpdateManager updateManager,
|
88
|
|
- final DialogManager dialogManager, final Window parentWindow) {
|
|
93
|
+ @Inject
|
|
94
|
+ public SwingUpdaterDialog(
|
|
95
|
+ final CachingUpdateManager updateManager,
|
|
96
|
+ final DialogManager dialogManager,
|
|
97
|
+ final MainFrame parentWindow,
|
|
98
|
+ final Provider<SwingRestartDialog> restartDialogProvider) {
|
89
|
99
|
super(dialogManager, parentWindow, ModalityType.MODELESS);
|
90
|
100
|
|
91
|
101
|
this.dialogManager = dialogManager;
|
92
|
102
|
this.updateManager = updateManager;
|
|
103
|
+ this.restartDialogProvider = restartDialogProvider;
|
93
|
104
|
|
94
|
105
|
initComponents();
|
95
|
106
|
layoutComponents();
|
|
@@ -199,7 +210,7 @@ public class SwingUpdaterDialog extends StandardDialog implements
|
199
|
210
|
}.executeInExecutor();
|
200
|
211
|
|
201
|
212
|
if (updateManager.getManagerStatus() == UpdateManagerStatus.IDLE_RESTART_NEEDED) {
|
202
|
|
- dialogManager.showDialog(SwingRestartDialog.class);
|
|
213
|
+ restartDialogProvider.get().displayOrRequestFocus();
|
203
|
214
|
dispose();
|
204
|
215
|
}
|
205
|
216
|
} else if (e.getSource().equals(getCancelButton())) {
|
|
@@ -227,7 +238,7 @@ public class SwingUpdaterDialog extends StandardDialog implements
|
227
|
238
|
|
228
|
239
|
if (status == UpdateManagerStatus.IDLE_RESTART_NEEDED) {
|
229
|
240
|
if (isVisible()) {
|
230
|
|
- dialogManager.showDialog(SwingRestartDialog.class);
|
|
241
|
+ restartDialogProvider.get().displayOrRequestFocus();
|
231
|
242
|
}
|
232
|
243
|
dispose();
|
233
|
244
|
} else {
|