-
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: buttons & kubejs is no longer broken
- Loading branch information
1 parent
e203d51
commit 7f9c97d
Showing
13 changed files
with
280 additions
and
34 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,28 @@ | ||
## 6.0.1 | ||
## 6.0.2 | ||
|
||
### Added | ||
|
||
- Added kubejs support back in for NeoForge as KubeJS no longer supports Forge or Fabric | ||
- Added support for custom buttons | ||
|
||
Buttons can be added by adding the following to the mods config file. You can have up to 2 buttons. Each button can have a label up to 32 characters long. | ||
|
||
If you do not want to have buttons, you can leave the buttons array empty. | ||
|
||
```json | ||
{ | ||
"buttons": [ | ||
{ | ||
"label": "Google", | ||
"url": "https://www.google.com" | ||
}, | ||
{ | ||
"label": "Yahoo", | ||
"url": "https://www.yahoo.com" | ||
} | ||
] | ||
} | ||
``` | ||
|
||
### Fixed | ||
|
||
- Fixed the borked reimplementation of KubeJS support. This should now work correctly. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
170 changes: 170 additions & 0 deletions
170
common/src/main/java/com/sunekaer/sdrp/discord/ExtendedRichPresence.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,170 @@ | ||
package com.sunekaer.sdrp.discord; | ||
|
||
import com.jagrosh.discordipc.entities.RichPresence; | ||
import org.jetbrains.annotations.Nullable; | ||
import org.json.JSONArray; | ||
import org.json.JSONObject; | ||
|
||
import java.time.OffsetDateTime; | ||
|
||
public class ExtendedRichPresence extends RichPresence { | ||
public @Nullable String button_label_1; | ||
public @Nullable String button_url_1; | ||
public @Nullable String button_label_2; | ||
public @Nullable String button_url_2; | ||
|
||
public ExtendedRichPresence(String state, String details, OffsetDateTime startTimestamp, OffsetDateTime endTimestamp, String largeImageKey, String largeImageText, String smallImageKey, String smallImageText, String partyId, int partySize, int partyMax, String matchSecret, String joinSecret, String spectateSecret, boolean instance) { | ||
super(state, details, startTimestamp, endTimestamp, largeImageKey, largeImageText, smallImageKey, smallImageText, partyId, partySize, partyMax, matchSecret, joinSecret, spectateSecret, instance); | ||
} | ||
|
||
public ExtendedRichPresence(String state, String details, OffsetDateTime startTimestamp, OffsetDateTime endTimestamp, String largeImageKey, String largeImageText, String smallImageKey, String smallImageText, String partyId, int partySize, int partyMax, String matchSecret, String joinSecret, String spectateSecret, boolean instance, @Nullable String button_label_1, @Nullable String button_url_1, @Nullable String button_label_2, @Nullable String button_url_2) { | ||
super(state, details, startTimestamp, endTimestamp, largeImageKey, largeImageText, smallImageKey, smallImageText, partyId, partySize, partyMax, matchSecret, joinSecret, spectateSecret, instance); | ||
this.button_label_1 = button_label_1; | ||
this.button_url_1 = button_url_1; | ||
this.button_label_2 = button_label_2; | ||
this.button_url_2 = button_url_2; | ||
} | ||
|
||
@Override | ||
public JSONObject toJson() { | ||
var jsonObject = super.toJson(); | ||
var buttonsObj = new JSONArray(); | ||
if (button_label_1 != null && button_url_1 != null) { | ||
var btn1 = new JSONObject(); | ||
btn1.put("label", button_label_1); | ||
btn1.put("url", button_url_1); | ||
buttonsObj.put(btn1); | ||
} | ||
if (button_label_2 != null && button_url_2 != null) { | ||
var btn2 = new JSONObject(); | ||
btn2.put("label", button_label_2); | ||
btn2.put("url", button_url_2); | ||
buttonsObj.put(btn2); | ||
} | ||
if (!buttonsObj.isEmpty()) { | ||
jsonObject.put("buttons", buttonsObj); | ||
if (jsonObject.has("secrets")) { | ||
jsonObject.remove("secrets"); | ||
} | ||
} | ||
return jsonObject; | ||
} | ||
|
||
public static class ExtendedBuilder { | ||
private String state; | ||
private String details; | ||
private OffsetDateTime startTimestamp; | ||
private OffsetDateTime endTimestamp; | ||
private String largeImageKey; | ||
private String largeImageText; | ||
private String smallImageKey; | ||
private String smallImageText; | ||
private String partyId; | ||
private int partySize; | ||
private int partyMax; | ||
private String matchSecret; | ||
private String joinSecret; | ||
private String spectateSecret; | ||
private boolean instance; | ||
|
||
private String button_label_1; | ||
private String button_url_1; | ||
private String button_label_2; | ||
private String button_url_2; | ||
|
||
public ExtendedBuilder setState(String state) { | ||
this.state = state; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setDetails(String details) { | ||
this.details = details; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setStartTimestamp(OffsetDateTime startTimestamp) { | ||
this.startTimestamp = startTimestamp; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setEndTimestamp(OffsetDateTime endTimestamp) { | ||
this.endTimestamp = endTimestamp; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setLargeImage(String largeImageKey, String largeImageText) { | ||
this.largeImageKey = largeImageKey; | ||
this.largeImageText = largeImageText; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setLargeImage(String largeImageKey) { | ||
return setLargeImage(largeImageKey, null); | ||
} | ||
|
||
public ExtendedBuilder setSmallImage(String smallImageKey, String smallImageText) { | ||
this.smallImageKey = smallImageKey; | ||
this.smallImageText = smallImageText; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setSmallImage(String smallImageKey) { | ||
return setSmallImage(smallImageKey, null); | ||
} | ||
|
||
public ExtendedBuilder setParty(String partyId, int partySize, int partyMax) { | ||
this.partyId = partyId; | ||
this.partySize = partySize; | ||
this.partyMax = partyMax; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setMatchSecret(String matchSecret) { | ||
this.matchSecret = matchSecret; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setJoinSecret(String joinSecret) { | ||
this.joinSecret = joinSecret; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setSpectateSecret(String spectateSecret) { | ||
this.spectateSecret = spectateSecret; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setInstance(boolean instance) { | ||
this.instance = instance; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setButton1(String label, String url) { | ||
// If the label is greater than 32 characters, it will be truncated. | ||
if (label.length() > 32) { | ||
// This is a failsafe | ||
label = label.substring(0, 32); | ||
} | ||
|
||
this.button_label_1 = label; | ||
this.button_url_1 = url; | ||
return this; | ||
} | ||
|
||
public ExtendedBuilder setButton2(String label, String url) { | ||
// If the label is greater than 32 characters, it will be truncated. | ||
if (label.length() > 32) { | ||
// This is a failsafe | ||
label = label.substring(0, 32); | ||
} | ||
|
||
this.button_label_2 = label; | ||
this.button_url_2 = url; | ||
return this; | ||
} | ||
|
||
public ExtendedRichPresence build() { | ||
return new ExtendedRichPresence(state, details, startTimestamp, endTimestamp, largeImageKey, largeImageText, smallImageKey, smallImageText, partyId, partySize, partyMax, matchSecret, joinSecret, spectateSecret, instance, button_label_1, button_url_1, button_label_2, button_url_2); | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
17 changes: 0 additions & 17 deletions
17
neoforge/src/main/java/com/sunekaer/sdrp/neoforge/SDRPForge.java
This file was deleted.
Oops, something went wrong.
21 changes: 21 additions & 0 deletions
21
neoforge/src/main/java/com/sunekaer/sdrp/neoforge/SDRPNeoForge.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
package com.sunekaer.sdrp.neoforge; | ||
|
||
import com.sunekaer.sdrp.SDRP; | ||
import com.sunekaer.sdrp.neoforge.kubejs.SDRPKubeJSIntegration; | ||
import dev.architectury.platform.Platform; | ||
import net.neoforged.fml.common.Mod; | ||
import net.neoforged.fml.loading.FMLEnvironment; | ||
|
||
@Mod(SDRP.MOD_ID) | ||
public class SDRPNeoForge { | ||
public SDRPNeoForge() { | ||
if (!FMLEnvironment.dist.isClient()) { | ||
return; | ||
} | ||
|
||
SDRP.init(); | ||
if (Platform.isModLoaded("kubejs")) { | ||
SDRPKubeJSIntegration.setup(); | ||
} | ||
} | ||
} |
Oops, something went wrong.