mirror of
https://github.com/SKCraft/Launcher.git
synced 2025-01-06 19:18:27 +01:00
Make the workspace frame load more responsively.
This commit is contained in:
parent
a11fed622e
commit
c5faed3c40
@ -6,6 +6,8 @@
|
|||||||
|
|
||||||
package com.skcraft.launcher.creator;
|
package com.skcraft.launcher.creator;
|
||||||
|
|
||||||
|
import com.google.common.util.concurrent.ListeningExecutorService;
|
||||||
|
import com.google.common.util.concurrent.MoreExecutors;
|
||||||
import com.skcraft.launcher.Launcher;
|
import com.skcraft.launcher.Launcher;
|
||||||
import com.skcraft.launcher.creator.controller.WelcomeController;
|
import com.skcraft.launcher.creator.controller.WelcomeController;
|
||||||
import com.skcraft.launcher.creator.dialog.WelcomeDialog;
|
import com.skcraft.launcher.creator.dialog.WelcomeDialog;
|
||||||
@ -21,11 +23,13 @@ import javax.swing.filechooser.FileSystemView;
|
|||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.Executors;
|
||||||
|
|
||||||
public class Creator {
|
public class Creator {
|
||||||
|
|
||||||
@Getter private final File dataDir;
|
@Getter private final File dataDir;
|
||||||
@Getter private final CreatorConfig config;
|
@Getter private final CreatorConfig config;
|
||||||
|
@Getter private final ListeningExecutorService executor = MoreExecutors.listeningDecorator(Executors.newCachedThreadPool());
|
||||||
|
|
||||||
public Creator() {
|
public Creator() {
|
||||||
this.dataDir = getAppDataDir();
|
this.dataDir = getAppDataDir();
|
||||||
|
@ -8,6 +8,9 @@ package com.skcraft.launcher.creator.controller;
|
|||||||
|
|
||||||
import com.google.common.base.Optional;
|
import com.google.common.base.Optional;
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
|
import com.google.common.util.concurrent.ListeningExecutorService;
|
||||||
|
import com.skcraft.concurrency.Deferred;
|
||||||
|
import com.skcraft.concurrency.Deferreds;
|
||||||
import com.skcraft.launcher.creator.Creator;
|
import com.skcraft.launcher.creator.Creator;
|
||||||
import com.skcraft.launcher.creator.dialog.AboutDialog;
|
import com.skcraft.launcher.creator.dialog.AboutDialog;
|
||||||
import com.skcraft.launcher.creator.dialog.PackManagerFrame;
|
import com.skcraft.launcher.creator.dialog.PackManagerFrame;
|
||||||
@ -16,10 +19,12 @@ import com.skcraft.launcher.creator.model.creator.RecentEntry;
|
|||||||
import com.skcraft.launcher.creator.model.creator.Workspace;
|
import com.skcraft.launcher.creator.model.creator.Workspace;
|
||||||
import com.skcraft.launcher.creator.model.swing.RecentListModel;
|
import com.skcraft.launcher.creator.model.swing.RecentListModel;
|
||||||
import com.skcraft.launcher.creator.swing.WorkspaceDirectoryFilter;
|
import com.skcraft.launcher.creator.swing.WorkspaceDirectoryFilter;
|
||||||
|
import com.skcraft.launcher.dialog.ProgressDialog;
|
||||||
import com.skcraft.launcher.persistence.Persistence;
|
import com.skcraft.launcher.persistence.Persistence;
|
||||||
import com.skcraft.launcher.swing.PopupMouseAdapter;
|
import com.skcraft.launcher.swing.PopupMouseAdapter;
|
||||||
import com.skcraft.launcher.swing.SwingHelper;
|
import com.skcraft.launcher.swing.SwingHelper;
|
||||||
import com.skcraft.launcher.util.MorePaths;
|
import com.skcraft.launcher.util.MorePaths;
|
||||||
|
import com.skcraft.launcher.util.SwingExecutor;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
@ -51,16 +56,17 @@ public class WelcomeController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private boolean openWorkspace(File dir) {
|
private boolean openWorkspace(File dir) {
|
||||||
try {
|
ListeningExecutorService executor = creator.getExecutor();
|
||||||
PackManagerFrame frame = new PackManagerFrame();
|
PackManagerFrame frame = new PackManagerFrame();
|
||||||
|
Deferred<?> deferred = Deferreds.makeDeferred(executor.submit(() -> {
|
||||||
PackManagerController controller = new PackManagerController(frame, dir, creator);
|
PackManagerController controller = new PackManagerController(frame, dir, creator);
|
||||||
addRecentEntry(dir);
|
addRecentEntry(dir);
|
||||||
controller.show();
|
return controller;
|
||||||
return true;
|
}), executor)
|
||||||
} catch (IOException e) {
|
.handleAsync(PackManagerController::show, ex -> {}, SwingExecutor.INSTANCE);
|
||||||
SwingHelper.showErrorDialog(dialog, "An unexpected error has occurred.", "Error", e);
|
SwingHelper.addErrorDialogCallback(frame, deferred);
|
||||||
return false;
|
|
||||||
}
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addRecentEntry(File dir) {
|
private void addRecentEntry(File dir) {
|
||||||
|
Loading…
Reference in New Issue
Block a user