Total berries leaderboard
This commit is contained in:
File diff suppressed because it is too large
Load Diff
@@ -19,6 +19,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
public Button selectionBerryButton;
|
||||
public Button selectionCoinButton;
|
||||
public Button selectionLegacyButton;
|
||||
public Button selectionTotalBerriesButton;
|
||||
|
||||
public GameObject scorePanel;
|
||||
public GameObject scoreContent;
|
||||
@@ -37,6 +38,10 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
public GameObject legacyContent;
|
||||
public GameObject legacySampleObject;
|
||||
|
||||
public GameObject totalBerriesPanel;
|
||||
public GameObject totalBerriesContent;
|
||||
public GameObject totalBerriesSampleObject;
|
||||
|
||||
public Dictionary<string, string> customIcons;
|
||||
|
||||
void Awake()
|
||||
@@ -45,6 +50,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
selectionBerryButton.onClick.AddListener(() => SwitchMenu(2));
|
||||
selectionCoinButton.onClick.AddListener(() => SwitchMenu(3));
|
||||
selectionLegacyButton.onClick.AddListener(() => SwitchMenu(4));
|
||||
selectionTotalBerriesButton.onClick.AddListener(() => SwitchMenu(5));
|
||||
|
||||
berryShowTypeDropdown.onValueChanged.AddListener(value => GetTopPlayersBerry(value));
|
||||
|
||||
@@ -52,7 +58,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
backButton.onClick.AddListener(async () =>
|
||||
{
|
||||
if (selectionPanel.activeSelf) await SceneManager.LoadSceneAsync("MainMenu");
|
||||
else if (scorePanel.activeSelf || berryPanel.activeSelf || coinPanel.activeSelf || legacyPanel.activeSelf) SwitchMenu(0);
|
||||
else if (scorePanel.activeSelf || berryPanel.activeSelf || coinPanel.activeSelf || legacyPanel.activeSelf || totalBerriesPanel.activeSelf) SwitchMenu(0);
|
||||
});
|
||||
refreshButton.onClick.AddListener(() =>
|
||||
{
|
||||
@@ -60,6 +66,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
else if (berryPanel.activeSelf) GetTopPlayersBerry(berryShowTypeDropdown.value);
|
||||
else if (coinPanel.activeSelf) GetTopPlayersCoin();
|
||||
else if (legacyPanel.activeSelf) GetTopPlayersLegacy();
|
||||
else if (totalBerriesPanel.activeSelf) GetTopPlayersTotalBerries();
|
||||
});
|
||||
}
|
||||
|
||||
@@ -106,6 +113,16 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (totalBerriesPanel.activeSelf)
|
||||
{
|
||||
foreach (Transform item in totalBerriesContent.transform)
|
||||
{
|
||||
if (item.gameObject.activeSelf)
|
||||
{
|
||||
Destroy(item.gameObject);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
switch (menu)
|
||||
{
|
||||
@@ -116,6 +133,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
berryPanel.SetActive(false);
|
||||
coinPanel.SetActive(false);
|
||||
legacyPanel.SetActive(false);
|
||||
totalBerriesPanel.SetActive(false);
|
||||
break;
|
||||
case 1:
|
||||
refreshButton.transform.localPosition = new UnityEngine.Vector2(-402.5f, -282.33f);
|
||||
@@ -126,6 +144,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
berryPanel.SetActive(false);
|
||||
coinPanel.SetActive(false);
|
||||
legacyPanel.SetActive(false);
|
||||
totalBerriesPanel.SetActive(false);
|
||||
break;
|
||||
case 2:
|
||||
refreshButton.transform.localPosition = new UnityEngine.Vector2(402.5f, 282.33f);
|
||||
@@ -137,6 +156,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
berryPanel.SetActive(true);
|
||||
coinPanel.SetActive(false);
|
||||
legacyPanel.SetActive(false);
|
||||
totalBerriesPanel.SetActive(false);
|
||||
break;
|
||||
case 3:
|
||||
refreshButton.transform.localPosition = new UnityEngine.Vector2(-402.5f, -282.33f);
|
||||
@@ -147,6 +167,7 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
berryPanel.SetActive(false);
|
||||
coinPanel.SetActive(true);
|
||||
legacyPanel.SetActive(false);
|
||||
totalBerriesPanel.SetActive(false);
|
||||
break;
|
||||
case 4:
|
||||
refreshButton.transform.localPosition = new UnityEngine.Vector2(-402.5f, -282.33f);
|
||||
@@ -157,6 +178,18 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
berryPanel.SetActive(false);
|
||||
coinPanel.SetActive(false);
|
||||
legacyPanel.SetActive(true);
|
||||
totalBerriesPanel.SetActive(false);
|
||||
break;
|
||||
case 5:
|
||||
refreshButton.transform.localPosition = new UnityEngine.Vector2(-402.5f, -282.33f);
|
||||
refreshButton.gameObject.SetActive(true);
|
||||
GetTopPlayersTotalBerries();
|
||||
selectionPanel.SetActive(false);
|
||||
scorePanel.SetActive(false);
|
||||
berryPanel.SetActive(false);
|
||||
coinPanel.SetActive(false);
|
||||
legacyPanel.SetActive(false);
|
||||
totalBerriesPanel.SetActive(true);
|
||||
break;
|
||||
}
|
||||
}
|
||||
@@ -668,6 +701,132 @@ public class LeaderboardsMenu : MonoBehaviour
|
||||
refreshButton.interactable = true;
|
||||
}
|
||||
|
||||
async void GetTopPlayersTotalBerries()
|
||||
{
|
||||
backButton.interactable = false;
|
||||
refreshButton.interactable = false;
|
||||
foreach (Transform item in totalBerriesContent.transform)
|
||||
{
|
||||
if (item.gameObject.activeSelf)
|
||||
{
|
||||
Destroy(item.gameObject);
|
||||
}
|
||||
}
|
||||
UpdateStatus(true, "Loading...");
|
||||
EncryptedWWWForm dataForm = new();
|
||||
dataForm.AddField("type", "4");
|
||||
using UnityWebRequest request = UnityWebRequest.Post(SensitiveInfo.SERVER_DATABASE_PREFIX + "getTopPlayers.php", dataForm.form);
|
||||
request.SetRequestHeader("Requester", "BerryDashClient");
|
||||
request.SetRequestHeader("ClientVersion", Application.version);
|
||||
request.SetRequestHeader("ClientPlatform", Application.platform.ToString());
|
||||
await request.SendWebRequest();
|
||||
if (request.result == UnityWebRequest.Result.Success)
|
||||
{
|
||||
UpdateStatus(false);
|
||||
string response = SensitiveInfo.Decrypt(request.downloadHandler.text, SensitiveInfo.SERVER_RECEIVE_TRANSFER_KEY);
|
||||
if (response == "-999")
|
||||
{
|
||||
UpdateStatus(true, "Server error while fetching data");
|
||||
}
|
||||
else if (response == "-998")
|
||||
{
|
||||
UpdateStatus(true, "Client version too outdated to access servers");
|
||||
}
|
||||
else if (response == "-997")
|
||||
{
|
||||
UpdateStatus(true, "Encryption/decryption issues");
|
||||
}
|
||||
else if (response == "-996")
|
||||
{
|
||||
UpdateStatus(true, "Can't send requests on self-built instance");
|
||||
}
|
||||
else if (response == "-1")
|
||||
{
|
||||
UpdateStatus(true, "No entries for this leaderboard found!");
|
||||
}
|
||||
else
|
||||
{
|
||||
var jsonResponse = JObject.Parse(response);
|
||||
var entries = (JArray)jsonResponse["entries"];
|
||||
customIcons = jsonResponse["customIcons"].ToObject<Dictionary<string, string>>();
|
||||
for (int i = 0; i < entries.Count; i++)
|
||||
{
|
||||
var entry = JObject.Parse(entries[i].ToString());
|
||||
var username = (string)entry["username"];
|
||||
var highScore = BigInteger.Parse((string)entry["value"]);
|
||||
var icon = (int)entry["icon"];
|
||||
var overlay = (int)entry["overlay"];
|
||||
var uid = BigInteger.Parse((string)entry["userid"]);
|
||||
var birdColor = (JArray)entry["birdColor"];
|
||||
var overlayColor = (JArray)entry["overlayColor"];
|
||||
var customIcon = (string)entry["customIcon"];
|
||||
|
||||
var entryInfo = Instantiate(totalBerriesSampleObject, totalBerriesContent.transform);
|
||||
var usernameText = entryInfo.transform.GetChild(0).GetComponent<TMP_Text>();
|
||||
var playerIcon = usernameText.transform.GetChild(0).GetComponent<Image>();
|
||||
var playerOverlayIcon = playerIcon.transform.GetChild(0).GetComponent<Image>();
|
||||
var highScoreText = entryInfo.transform.GetChild(1).GetComponent<TMP_Text>();
|
||||
|
||||
if (BazookaManager.Instance.GetAccountID() == uid)
|
||||
{
|
||||
usernameText.color = Color.aquamarine;
|
||||
highScoreText.color = Color.aquamarine;
|
||||
}
|
||||
|
||||
usernameText.text = $"{username} (#{i + 1})";
|
||||
highScoreText.text += Tools.FormatWithCommas(highScore);
|
||||
if (customIcon == null)
|
||||
{
|
||||
playerIcon.sprite = Resources.Load<Sprite>("Icons/Icons/bird_" + icon);
|
||||
if (icon == 1)
|
||||
{
|
||||
playerIcon.sprite = Tools.GetIconForUser(uid);
|
||||
}
|
||||
playerOverlayIcon.sprite = Resources.Load<Sprite>("Icons/Overlays/overlay_" + overlay);
|
||||
if (overlay == 0)
|
||||
{
|
||||
playerOverlayIcon.gameObject.SetActive(false);
|
||||
}
|
||||
else if (overlay == 8)
|
||||
{
|
||||
playerOverlayIcon.transform.localPosition = new UnityEngine.Vector2(-16.56f, 14.81f);
|
||||
}
|
||||
else if (overlay == 11)
|
||||
{
|
||||
playerOverlayIcon.transform.localPosition = new UnityEngine.Vector2(-14.74451f, 20.39122f);
|
||||
}
|
||||
else if (overlay == 13)
|
||||
{
|
||||
playerOverlayIcon.transform.localPosition = new UnityEngine.Vector2(-16.54019f, 14.70365f);
|
||||
}
|
||||
try
|
||||
{
|
||||
playerIcon.color = new Color((int)birdColor[0] / 255f, (int)birdColor[1] / 255f, (int)birdColor[2] / 255f);
|
||||
playerOverlayIcon.color = new Color((int)overlayColor[0] / 255f, (int)overlayColor[1] / 255f, (int)overlayColor[2] / 255f);
|
||||
}
|
||||
catch (Exception)
|
||||
{
|
||||
playerIcon.color = Color.white;
|
||||
playerOverlayIcon.color = Color.white;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
Tools.RenderFromBase64(customIcons[customIcon], playerIcon);
|
||||
playerOverlayIcon.gameObject.SetActive(false);
|
||||
}
|
||||
entryInfo.SetActive(true);
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
UpdateStatus(true, "Failed to fetch leaderboard stats");
|
||||
}
|
||||
backButton.interactable = true;
|
||||
refreshButton.interactable = true;
|
||||
}
|
||||
|
||||
private void UpdateStatus(bool enabled, string message = "")
|
||||
{
|
||||
statusText.gameObject.SetActive(enabled);
|
||||
|
||||
Reference in New Issue
Block a user