aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorhannibal2 <24389977+hannibal00212@users.noreply.github.com>2023-06-10 11:32:32 +0200
committerhannibal2 <24389977+hannibal00212@users.noreply.github.com>2023-06-10 11:32:32 +0200
commit7d0875bf2218c9e03712f549baa6471221ff7140 (patch)
treef46ed7a378d2c1e7402c8249ed8bf5698ba96982 /src
parente43939a64c9c7b8a5164066a63897dbba0a34afb (diff)
downloadskyhanni-7d0875bf2218c9e03712f549baa6471221ff7140.tar.gz
skyhanni-7d0875bf2218c9e03712f549baa6471221ff7140.tar.bz2
skyhanni-7d0875bf2218c9e03712f549baa6471221ff7140.zip
Added City Project Daily Reminder
Diffstat (limited to 'src')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/Storage.java3
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt2
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/features/Misc.java5
-rw-r--r--src/main/java/at/hannibal2/skyhanni/features/misc/CityProjectFeatures.kt91
4 files changed, 85 insertions, 16 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/config/Storage.java b/src/main/java/at/hannibal2/skyhanni/config/Storage.java
index 1807e2e22..2de960a30 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/Storage.java
+++ b/src/main/java/at/hannibal2/skyhanni/config/Storage.java
@@ -186,5 +186,8 @@ public class Storage {
public Map<FarmingItems, ItemStack> farmingItems = new HashMap<>();
}
}
+
+ @Expose
+ public long nextCityProjectParticipationTime = 0L;
}
} \ No newline at end of file
diff --git a/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt b/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt
index 147734b30..bcddda8df 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt
+++ b/src/main/java/at/hannibal2/skyhanni/config/commands/Commands.kt
@@ -18,6 +18,7 @@ import at.hannibal2.skyhanni.features.garden.farming.GardenStartLocation
import at.hannibal2.skyhanni.features.garden.fortuneguide.CaptureFarmingGear
import at.hannibal2.skyhanni.features.garden.fortuneguide.FFGuideGUI
import at.hannibal2.skyhanni.features.minion.MinionFeatures
+import at.hannibal2.skyhanni.features.misc.CityProjectFeatures
import at.hannibal2.skyhanni.features.misc.CollectionCounter
import at.hannibal2.skyhanni.features.misc.MarkedPlayerManager
import at.hannibal2.skyhanni.features.misc.discordrpc.DiscordRPCManager
@@ -61,6 +62,7 @@ object Commands {
registerCommand("shshareinquis") { InquisitorWaypointShare.sendInquisitor() }
registerCommand("shrpcstart") { DiscordRPCManager.startCommand() }
registerCommand("shcropstartlocation") { GardenStartLocation.setLocationCommand() }
+ registerCommand("shstopcityprojectreminder") { CityProjectFeatures.disable() }
// for users - fix bugs
registerCommand("shupdaterepo") { SkyHanniMod.repo.updateRepo() }
diff --git a/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java b/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java
index bf2baef35..97a885cdc 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java
+++ b/src/main/java/at/hannibal2/skyhanni/config/features/Misc.java
@@ -382,6 +382,11 @@ public class Misc {
public boolean showReady = true;
@Expose
+ @ConfigOption(name = "Daily Reminder", desc = "Remind every 24 hours to participate.")
+ @ConfigEditorBoolean
+ public boolean dailyReminder = true;
+
+ @Expose
public Position pos = new Position(150, 150, false, true);
}
diff --git a/src/main/java/at/hannibal2/skyhanni/features/misc/CityProjectFeatures.kt b/src/main/java/at/hannibal2/skyhanni/features/misc/CityProjectFeatures.kt
index bc71d58a3..3d3a0035d 100644
--- a/src/main/java/at/hannibal2/skyhanni/features/misc/CityProjectFeatures.kt
+++ b/src/main/java/at/hannibal2/skyhanni/features/misc/CityProjectFeatures.kt
@@ -1,10 +1,12 @@
package at.hannibal2.skyhanni.features.misc
import at.hannibal2.skyhanni.SkyHanniMod
+import at.hannibal2.skyhanni.data.ProfileStorageData
import at.hannibal2.skyhanni.events.GuiContainerEvent
import at.hannibal2.skyhanni.events.GuiRenderEvent
import at.hannibal2.skyhanni.events.InventoryCloseEvent
import at.hannibal2.skyhanni.events.InventoryOpenEvent
+import at.hannibal2.skyhanni.features.garden.contest.FarmingContestAPI
import at.hannibal2.skyhanni.utils.*
import at.hannibal2.skyhanni.utils.ItemUtils.getLore
import at.hannibal2.skyhanni.utils.ItemUtils.name
@@ -12,6 +14,7 @@ import at.hannibal2.skyhanni.utils.LorenzUtils.addAsSingletonList
import at.hannibal2.skyhanni.utils.NumberUtil.addSeparators
import at.hannibal2.skyhanni.utils.RenderUtils.highlight
import at.hannibal2.skyhanni.utils.RenderUtils.renderStringsAndItems
+import at.hannibal2.skyhanni.utils.StringUtils.matchMatcher
import at.hannibal2.skyhanni.utils.StringUtils.removeColor
import at.hannibal2.skyhanni.utils.renderables.Renderable
import net.minecraft.client.Minecraft
@@ -20,11 +23,53 @@ import net.minecraft.client.gui.inventory.GuiEditSign
import net.minecraft.inventory.ContainerChest
import net.minecraft.item.ItemStack
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent
+import net.minecraftforge.fml.common.gameevent.TickEvent
class CityProjectFeatures {
- private val config get() = SkyHanniMod.feature.misc.cityProject
private var display = listOf<List<Any>>()
private var inInventory = false
+ private var tick = 0
+ private var lastReminderSend = 0L
+ private val contributeAgainPattern = "§7Contribute again: §e(?<time>.*)".toPattern()
+
+ companion object {
+ private val config get() = SkyHanniMod.feature.misc.cityProject
+ fun disable() {
+ config.showReady = false
+ LorenzUtils.chat("§c[SkyHanni] Disabled city project reminder messages!")
+ }
+ }
+
+ @SubscribeEvent
+ fun onTick(event: TickEvent.ClientTickEvent) {
+ if (!LorenzUtils.inSkyBlock) return
+ if (event.phase != TickEvent.Phase.START) return
+ tick++
+ if (tick % 20 == 0) {
+ checkDailyReminder()
+ }
+ }
+
+ private fun checkDailyReminder() {
+ if (!config.dailyReminder) return
+ val profileSpecific = ProfileStorageData.profileSpecific ?: return
+ if (LorenzUtils.inDungeons) return
+ if (LorenzUtils.inKuudraFight) return
+ if (FarmingContestAPI.inContest) return
+
+ if (LorenzUtils.skyBlockArea == "Community Center") return
+
+ if (profileSpecific.nextCityProjectParticipationTime == 0L) return
+ if (System.currentTimeMillis() <= profileSpecific.nextCityProjectParticipationTime) return
+
+ if (lastReminderSend + 10_000 > System.currentTimeMillis()) return
+ lastReminderSend = System.currentTimeMillis()
+
+ LorenzUtils.clickableChat(
+ "§e[SkyHanni] Daily City Project Reminder! (Click here to disable this reminder)",
+ "shstopcityprojectreminder"
+ )
+ }
@SubscribeEvent
fun onInventoryClose(event: InventoryCloseEvent) {
@@ -34,24 +79,43 @@ class CityProjectFeatures {
@SubscribeEvent
fun onInventoryOpen(event: InventoryOpenEvent) {
if (!LorenzUtils.inSkyBlock) return
- if (!config.showMaterials) return
val lore = event.inventoryItems[4]?.getLore() ?: return
if (lore.isEmpty()) return
if (lore[0] != "§8City Project") return
inInventory = true
- // internal name -> amount
- val materials = mutableMapOf<String, Int>()
- for ((_, item) in event.inventoryItems) {
- val itemName = item.name ?: continue
- if (itemName != "§eContribute this component!") continue
- fetchMaterials(item, materials)
- }
+ if (config.showMaterials) {
+ // internal name -> amount
+ val materials = mutableMapOf<String, Int>()
+ for ((_, item) in event.inventoryItems) {
+ val itemName = item.name ?: continue
+ if (itemName != "§eContribute this component!") continue
+ fetchMaterials(item, materials)
+ }
- println("materials: $materials")
+ display = buildList(materials)
+ }
- display = buildList(materials)
+ if (config.showReady) {
+ var nextTime = Long.MAX_VALUE
+ for ((_, item) in event.inventoryItems) {
+ val itemName = item.name ?: continue
+
+ for (line in item.getLore()) {
+ contributeAgainPattern.matchMatcher(line) {
+ val duration = TimeUtils.getMillis(group("time"))
+ val endTime = System.currentTimeMillis() + duration
+ if (endTime < nextTime) {
+ nextTime = endTime
+ }
+ }
+ }
+ if (itemName != "§eContribute this component!") continue
+ nextTime = System.currentTimeMillis()
+ ProfileStorageData.profileSpecific?.nextCityProjectParticipationTime = nextTime
+ }
+ }
}
private fun buildList(materials: MutableMap<String, Int>) = buildList<List<Any>> {
@@ -96,13 +160,9 @@ class CityProjectFeatures {
if (line == "") break
if (line.contains("Bits")) break
- println(" ")
- println("line: '$line'")
val (name, amount) = ItemUtils.readItemAmount(line)
if (name != null) {
val internalName = NEUItems.getInternalName(name)
- println("internalName: $internalName")
- println("amount: $amount")
val old = materials.getOrPut(internalName) { 0 }
materials[internalName] = old + amount
}
@@ -141,5 +201,4 @@ class CityProjectFeatures {
}
}
}
-
}