This commit is contained in:
Michael Ziluck 2019-06-03 14:33:01 -05:00
parent a3a6e21f64
commit c3d3ad6d66
6 changed files with 46 additions and 28 deletions

View File

@ -6,7 +6,7 @@
<groupId>com.alttd</groupId>
<artifactId>AltitudeTag</artifactId>
<version>1.0.1</version>
<version>1.0.2</version>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

View File

@ -114,17 +114,17 @@ public class AltitudeTag extends JavaPlugin
*
* @param tagger the new tagger.
*/
public static void setTagger(UUID tagger)
public static void setTagger(UUID tagger, TagCause cause)
{
// announce that a new person is it
Player previousPlayer = Bukkit.getPlayer(instance.tagger);
if (tagger != null)
{
NotificationHandler.sendGlobalNotifications(previousPlayer != null
? previousPlayer.getName()
: null, Bukkit.getPlayer(tagger).getName());
NotificationHandler.sendGlobalNotifications(previousPlayer != null ? previousPlayer.getName() : null,
Bukkit.getPlayer(tagger).getName(),
cause);
}
instance.tagger = tagger;
}

View File

@ -64,15 +64,21 @@ public class NotificationHandler
});
}
public static void sendGlobalNotifications(String attacker, String victim)
public static void sendGlobalNotifications(String attacker, String victim, TagCause cause)
{
if (attacker == null && Config.NOTIFICATION_GLOBAL_CHAT_OTHER_REASON_ENABLED.getValue())
if (cause == TagCause.DISCONNECT_EMPTY)
{
return;
}
if (cause != TagCause.NORMAL && Config.NOTIFICATION_GLOBAL_CHAT_OTHER_REASON_ENABLED.getValue())
{
// TODO make this actually do what it's supposed to
Bukkit.getOnlinePlayers().forEach(p -> p.sendMessage(Lang.renderString(Config.NOTIFICATION_GLOBAL_CHAT_OTHER_REASON_MESSAGE.getValue(),
"{target}", victim)));
}
if (attacker != null && Config.NOTIFICATION_GLOBAL_CHAT_AFTER_TAG_ENABLED.getValue())
if (cause == TagCause.NORMAL && Config.NOTIFICATION_GLOBAL_CHAT_AFTER_TAG_ENABLED.getValue())
{
Bukkit.getOnlinePlayers().forEach(p -> p.sendMessage(Lang.renderString(Config.NOTIFICATION_GLOBAL_CHAT_AFTER_TAG_MESSAGE.getValue(),
"{target}", victim,

View File

@ -0,0 +1,10 @@
package com.alttd.altitudetag;
public enum TagCause
{
NORMAL,
TIMEOUT,
DISCONNECT_TRANSFER,
DISCONNECT_EMPTY,
FIRST_CONNECT
}

View File

@ -1,10 +1,10 @@
package com.alttd.altitudetag.listeners;
import java.util.Optional;
import java.util.UUID;
import com.alttd.altitudetag.AltitudeTag;
import com.alttd.altitudetag.NotificationHandler;
import com.alttd.altitudetag.TagCause;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
@ -19,7 +19,7 @@ public class ConnectionListener implements Listener
{
if (AltitudeTag.getTagger() == null)
{
AltitudeTag.setTagger(event.getPlayer().getUniqueId());
AltitudeTag.setTagger(event.getPlayer().getUniqueId(), TagCause.FIRST_CONNECT);
}
if (AltitudeTag.getBossBar() != null)
{
@ -30,23 +30,24 @@ public class ConnectionListener implements Listener
@EventHandler
public void onLeave(PlayerQuitEvent event)
{
if (event.getPlayer().getUniqueId().equals(AltitudeTag.getTagger()))
if (!event.getPlayer().getUniqueId().equals(AltitudeTag.getTagger()))
{
if (Bukkit.getOnlinePlayers().size() == 1)
{
AltitudeTag.setTagger(null);
}
else
{
Optional<? extends Player> optional = Bukkit.getOnlinePlayers().stream().filter(p -> p != event.getPlayer()).findAny();
if (!optional.isPresent())
{
throw new IllegalStateException("There is more than one player on but for some reason they are all: " + event.getPlayer().getUniqueId());
}
UUID uuid = optional.get().getUniqueId();
AltitudeTag.setTagger(uuid);
NotificationHandler.sendVictimTitle(optional.get(), false);
}
return;
}
if (Bukkit.getOnlinePlayers().size() == 1)
{
AltitudeTag.setTagger(null, TagCause.DISCONNECT_EMPTY);
return;
}
Optional<? extends Player> optional = Bukkit.getOnlinePlayers().stream().filter(p -> p != event.getPlayer()).findAny();
if (!optional.isPresent())
{
throw new IllegalStateException("There is more than one player on but for some reason they are all: " + event.getPlayer().getUniqueId());
}
Player player = optional.get();
AltitudeTag.setTagger(player.getUniqueId(), TagCause.DISCONNECT_TRANSFER);
NotificationHandler.sendVictimTitle(player, false);
}
}

View File

@ -2,6 +2,7 @@ package com.alttd.altitudetag.listeners;
import com.alttd.altitudetag.AltitudeTag;
import com.alttd.altitudetag.NotificationHandler;
import com.alttd.altitudetag.TagCause;
import org.bukkit.entity.Player;
import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener;
@ -32,7 +33,7 @@ public class InteractListener implements Listener
}
});
AltitudeTag.setTagger(tagged.getUniqueId());
AltitudeTag.setTagger(tagged.getUniqueId(), TagCause.NORMAL);
NotificationHandler.sendVictimTitle(tagged, false);
}