Skip to content

Commit eed3cc1

Browse files
committed
add icon to taskbar, add view cts modlist as option in fabric when done installing
1 parent 3cdad23 commit eed3cc1

File tree

4 files changed

+44
-21
lines changed

4 files changed

+44
-21
lines changed

src/main/java/com/nexia/installer/InstallerGUI.java

+17-1
Original file line numberDiff line numberDiff line change
@@ -6,6 +6,7 @@
66
import javax.swing.*;
77
import java.awt.*;
88
import java.io.File;
9+
import java.lang.reflect.Method;
910
import java.util.function.Consumer;
1011
import java.util.function.Supplier;
1112

@@ -57,14 +58,29 @@ public static void load() throws UnsupportedLookAndFeelException, ClassNotFoundE
5758

5859
gui.setContentPane(gui.pane);
5960

60-
6161
gui.updateSize(true);
6262
gui.setTitle(Main.BUNDLE.getString("installer.title"));
63+
6364
gui.setIconImage(Main.icon);
65+
gui.setTaskBarImage(Main.icon);
66+
6467
gui.setLocationRelativeTo(null);
6568
gui.setVisible(true);
6669
}
6770

71+
private void setTaskBarImage(Image image) {
72+
try {
73+
// Only supported in Java 9 +
74+
Class<?> taskbarClass = Class.forName("java.awt.Taskbar");
75+
Method getTaskbar = taskbarClass.getDeclaredMethod("getTaskbar");
76+
Method setIconImage = taskbarClass.getDeclaredMethod("setIconImage", Image.class);
77+
Object taskbar = getTaskbar.invoke(null);
78+
setIconImage.invoke(taskbar, image);
79+
} catch (Exception e) {
80+
// Ignored, running on Java 8
81+
}
82+
}
83+
6884
private void updateSize(boolean updateMinimum) {
6985
if (updateMinimum) setMinimumSize(null);
7086
setPreferredSize(null);

src/main/java/com/nexia/installer/game/VersionHandler.java

+13-15
Original file line numberDiff line numberDiff line change
@@ -6,23 +6,23 @@
66
public class VersionHandler {
77
public static List<GameVersion> versions = new ArrayList<>();
88

9-
public static GameVersion CombatTest8c = new GameVersion("Combat Test 8c", "1.16_combat-6", new Download("f76157734ee0611fbef7d636156f20fa67c34514", 7463, "https://www.rizecookey.net/dl/file/combat-test-patched/1_16_combat-6.zip"));
9+
public static GameVersion CombatTest8c = new GameVersion("Combat Test 8c", "1.16_combat-6", new Download("f76157734ee0611fbef7d636156f20fa67c34514", "https://www.rizecookey.net/dl/file/combat-test-patched/1_16_combat-6.zip"));
1010

11-
public static GameVersion CombatTest8b = new GameVersion("Combat Test 8b", "1.16_combat-5", new Download("9b2b984d635d373564b50803807225c75d7fd447", 7044, "https://launcher.mojang.com/experiments/combat/9b2b984d635d373564b50803807225c75d7fd447/1_16_combat-5.zip"));
11+
public static GameVersion CombatTest8b = new GameVersion("Combat Test 8b", "1.16_combat-5", new Download("9b2b984d635d373564b50803807225c75d7fd447", "https://launcher.mojang.com/experiments/combat/9b2b984d635d373564b50803807225c75d7fd447/1_16_combat-5.zip"));
1212

13-
public static GameVersion CombatTest8 = new GameVersion("Combat Test 8", "1.16_combat-4", new Download("b4306b421183bd084b2831bd8d33a5db05ae9f9c", 7046, "https://cdn.discordapp.com/attachments/369990015096455168/947864881028272198/1_16_combat-4.zip"));
13+
public static GameVersion CombatTest8 = new GameVersion("Combat Test 8", "1.16_combat-4", new Download("b4306b421183bd084b2831bd8d33a5db05ae9f9c", "https://cdn.discordapp.com/attachments/369990015096455168/947864881028272198/1_16_combat-4.zip"));
1414

15-
public static GameVersion CombatTest7c = new GameVersion("Combat Test 7c", "1.16_combat-3", new Download("2557b99d95588505e988886220779087d7d6b1e9", 7049, "https://piston-data.mojang.com/experiments/combat/2557b99d95588505e988886220779087d7d6b1e9/1_16_combat-3.zip"));
15+
public static GameVersion CombatTest7c = new GameVersion("Combat Test 7c", "1.16_combat-3", new Download("2557b99d95588505e988886220779087d7d6b1e9", "https://piston-data.mojang.com/experiments/combat/2557b99d95588505e988886220779087d7d6b1e9/1_16_combat-3.zip"));
1616

17-
public static GameVersion CombatTest7b = new GameVersion("Combat Test 7b", "1.16_combat-2", new Download("43266ea8f2c20601d9fb264d5aa85df8052abc9e", 7051, "https://archive.org/download/Combat_Test_7ab/1_16_combat-2.zip"));
18-
public static GameVersion CombatTest7 = new GameVersion("Combat Test 7", "1.16_combat-1", new Download("47bb5be6cb3ba215539ee97dfae66724c73c3dd5", 7045, "https://archive.org/download/Combat_Test_7ab/1_16_combat-1.zip"));
17+
public static GameVersion CombatTest7b = new GameVersion("Combat Test 7b", "1.16_combat-2", new Download("43266ea8f2c20601d9fb264d5aa85df8052abc9e", "https://archive.org/download/Combat_Test_7ab/1_16_combat-2.zip"));
18+
public static GameVersion CombatTest7 = new GameVersion("Combat Test 7", "1.16_combat-1", new Download("47bb5be6cb3ba215539ee97dfae66724c73c3dd5", "https://archive.org/download/Combat_Test_7ab/1_16_combat-1.zip"));
1919

20-
public static GameVersion CombatTest6 = new GameVersion("Combat Test 6", "1.16_combat-0", new Download("5a8ceec8681ed96ab6ecb9607fb5d19c8a755559", 7049, "https://piston-data.mojang.com/experiments/combat/5a8ceec8681ed96ab6ecb9607fb5d19c8a755559/1_16_combat-0.zip"));
21-
public static GameVersion CombatTest5 = new GameVersion("Combat Test 5", "1.15_combat-6", new Download("52263d42a626b40c947e523128f7a195ec5af76a", 7061, "https://piston-data.mojang.com/experiments/combat/52263d42a626b40c947e523128f7a195ec5af76a/1_15_combat-6.zip"));
22-
public static GameVersion CombatTest4 = new GameVersion("Combat Test 4", "1.15_combat-1", new Download("ac11ea96f3bb2fa2b9b76ab1d20cacb1b1f7ef60", 7059, "https://piston-data.mojang.com/experiments/combat/ac11ea96f3bb2fa2b9b76ab1d20cacb1b1f7ef60/1_15_combat-1.zip"));
23-
public static GameVersion CombatTest3 = new GameVersion("Combat Test 3", "1.14_combat-3", new Download("0f209c9c84b81c7d4c88b4632155b9ae550beb89", 6433, "https://piston-data.mojang.com/experiments/combat/0f209c9c84b81c7d4c88b4632155b9ae550beb89/1_14_combat-3.zip"));
24-
public static GameVersion CombatTest2 = new GameVersion("Combat Test 2", "1.14_combat-0", new Download("d164bb6ecc5fca9ac02878c85f11befae61ac1ca", 6287, "https://piston-data.mojang.com/experiments/combat/d164bb6ecc5fca9ac02878c85f11befae61ac1ca/1_14_combat-0.zip"));
25-
public static GameVersion CombatTest1 = new GameVersion("1.14.3 - Combat Test", "1.14_combat-212796", new Download("610f5c9874ba8926d5ae1bcce647e5f0e6e7c889",4843, "https://piston-data.mojang.com/experiments/combat/610f5c9874ba8926d5ae1bcce647e5f0e6e7c889/1_14_combat-212796.zip"));
20+
public static GameVersion CombatTest6 = new GameVersion("Combat Test 6", "1.16_combat-0", new Download("5a8ceec8681ed96ab6ecb9607fb5d19c8a755559", "https://piston-data.mojang.com/experiments/combat/5a8ceec8681ed96ab6ecb9607fb5d19c8a755559/1_16_combat-0.zip"));
21+
public static GameVersion CombatTest5 = new GameVersion("Combat Test 5", "1.15_combat-6", new Download("52263d42a626b40c947e523128f7a195ec5af76a", "https://piston-data.mojang.com/experiments/combat/52263d42a626b40c947e523128f7a195ec5af76a/1_15_combat-6.zip"));
22+
public static GameVersion CombatTest4 = new GameVersion("Combat Test 4", "1.15_combat-1", new Download("ac11ea96f3bb2fa2b9b76ab1d20cacb1b1f7ef60", "https://piston-data.mojang.com/experiments/combat/ac11ea96f3bb2fa2b9b76ab1d20cacb1b1f7ef60/1_15_combat-1.zip"));
23+
public static GameVersion CombatTest3 = new GameVersion("Combat Test 3", "1.14_combat-3", new Download("0f209c9c84b81c7d4c88b4632155b9ae550beb89", "https://piston-data.mojang.com/experiments/combat/0f209c9c84b81c7d4c88b4632155b9ae550beb89/1_14_combat-3.zip"));
24+
public static GameVersion CombatTest2 = new GameVersion("Combat Test 2", "1.14_combat-0", new Download("d164bb6ecc5fca9ac02878c85f11befae61ac1ca", "https://piston-data.mojang.com/experiments/combat/d164bb6ecc5fca9ac02878c85f11befae61ac1ca/1_14_combat-0.zip"));
25+
public static GameVersion CombatTest1 = new GameVersion("1.14.3 - Combat Test", "1.14_combat-212796", new Download("610f5c9874ba8926d5ae1bcce647e5f0e6e7c889", "https://piston-data.mojang.com/experiments/combat/610f5c9874ba8926d5ae1bcce647e5f0e6e7c889/1_14_combat-212796.zip"));
2626

2727
public static class GameVersion {
2828
String version;
@@ -52,12 +52,10 @@ public Download getDownload() {
5252

5353
public static class Download {
5454
public final String sha1;
55-
public final long size;
5655
public final String url;
5756

58-
public Download(String sha1, long size, String url) {
57+
public Download(String sha1, String url) {
5958
this.sha1 = sha1;
60-
this.size = size;
6159
this.url = url;
6260
}
6361
}

src/main/java/com/nexia/installer/util/fabric/FabricInstallerHelper.java

+13-4
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,8 @@
1111
import java.io.BufferedInputStream;
1212
import java.io.File;
1313
import java.io.IOException;
14+
import java.net.URI;
15+
import java.net.URISyntaxException;
1416
import java.net.URL;
1517
import java.nio.file.Files;
1618
import java.nio.file.Path;
@@ -171,7 +173,7 @@ private File getJarFile() throws IOException {
171173

172174
private String getFabricVersion() {
173175

174-
String version = "0.11.2";
176+
String version = "1.0.0";
175177

176178
try {
177179
String response = HttpAPI.get("https://api.github.com/repos/rizecookey/fabric-installer/releases/latest");
@@ -184,8 +186,8 @@ private String getFabricVersion() {
184186
} catch (Exception ignored) { return version; }
185187
}
186188

187-
private void showDone(FabricVersionHandler.GameVersion gameVersion) {
188-
Object[] options = {"OK", "Install Vanilla"};
189+
private void showDone(FabricVersionHandler.GameVersion gameVersion) throws URISyntaxException, IOException {
190+
Object[] options = {"OK", "View CTS Mod List"};
189191
int result = JOptionPane.showOptionDialog(null,
190192
MessageFormat.format(Main.BUNDLE.getString("installer.prompt.install.done.fabric"), gameVersion.getVersion()),
191193
Main.BUNDLE.getString("installer.title"),
@@ -196,7 +198,14 @@ private void showDone(FabricVersionHandler.GameVersion gameVersion) {
196198
options[0]
197199
);
198200

199-
if(result == JOptionPane.NO_OPTION) InstallerGUI.instance.pane.setSelectedComponent(InstallerGUI.instance.vanilla);
201+
if(result == JOptionPane.NO_OPTION) {
202+
URI url = new URI("https://github.com/nexia-cts/cts-mod-list");
203+
if (Desktop.isDesktopSupported() && Desktop.getDesktop().isSupported(Desktop.Action.BROWSE)) {
204+
Desktop.getDesktop().browse(url);
205+
} else {
206+
throw new UnsupportedOperationException("Failed to open " + url.toURL());
207+
}
208+
}
200209
}
201210
}
202211

src/main/resources/lang/installer.properties

+1-1
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ installer.prompt.game.version=Minecraft Version:
22
installer.prompt.select.location=Select Install Location:
33
installer.button.install=Install
44
installer.prompt.install.done={0} has been installed, if you want to install fabric then click on the "Install Fabric" button.
5-
installer.prompt.install.done.fabric={0} has been installed, if you want to install vanilla then click on the "Install Vanilla" button.
5+
installer.prompt.install.done.fabric={0} has been installed, if you want mods for fabric then you should check out the CTS Mod List by clicking on the "View CTS Mod List" button.
66
installer.exception.no.launcher.directory=No launcher directory found!
77
installer.exception.no.launcher.profile=No launcher profile.json found!
88
installer.prompt.launcher.type.body=The Combat Test Installer has detected 2 different installations of the Minecraft Launcher, which launcher do you wish to install the Combat Tests to?\n\n- Select Microsoft Store if you are playing Minecraft through the Xbox App or the Windows Store.\n- Select Standalone if you downloaded the Minecraft launcher directly from the Minecraft.net website.\n\nIf you are unsure try the Microsoft Store option first, you can always re-run the installer.

0 commit comments

Comments
 (0)