first add
This commit is contained in:
@@ -0,0 +1,47 @@
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<groupId>com.dirtbagmc</groupId>
|
||||
<artifactId>DirtJoin</artifactId>
|
||||
<version>1.0-SNAPSHOT</version>
|
||||
<packaging>jar</packaging>
|
||||
|
||||
<name>DirtJoin</name>
|
||||
<description>First join effects plugin for Paper</description>
|
||||
|
||||
<properties>
|
||||
<maven.compiler.release>21</maven.compiler.release>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
</properties>
|
||||
|
||||
<repositories>
|
||||
<repository>
|
||||
<id>papermc-repo</id>
|
||||
<url>https://repo.papermc.io/repository/maven-public/</url>
|
||||
</repository>
|
||||
</repositories>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>io.papermc.paper</groupId>
|
||||
<artifactId>paper-api</artifactId>
|
||||
<version>1.21.1-R0.1-SNAPSHOT</version>
|
||||
<scope>provided</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
|
||||
<build>
|
||||
<plugins>
|
||||
<plugin>
|
||||
<groupId>org.apache.maven.plugins</groupId>
|
||||
<artifactId>maven-compiler-plugin</artifactId>
|
||||
<version>3.13.0</version>
|
||||
<configuration>
|
||||
<release>21</release>
|
||||
</configuration>
|
||||
</plugin>
|
||||
</plugins>
|
||||
</build>
|
||||
</project>
|
||||
@@ -0,0 +1,277 @@
|
||||
package com.dirtbagmc.dirtjoin;
|
||||
|
||||
import net.kyori.adventure.text.Component;
|
||||
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
|
||||
import org.bukkit.Bukkit;
|
||||
import org.bukkit.Location;
|
||||
import org.bukkit.NamespacedKey;
|
||||
import org.bukkit.Particle;
|
||||
import org.bukkit.Registry;
|
||||
import org.bukkit.Sound;
|
||||
import org.bukkit.SoundCategory;
|
||||
import org.bukkit.command.Command;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.command.TabExecutor;
|
||||
import org.bukkit.configuration.file.FileConfiguration;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
import org.bukkit.potion.PotionEffect;
|
||||
import org.bukkit.potion.PotionEffectType;
|
||||
import org.bukkit.scheduler.BukkitTask;
|
||||
|
||||
import java.time.Duration;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Locale;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
|
||||
public class DirtJoinPlugin extends JavaPlugin implements TabExecutor {
|
||||
|
||||
private final Map<UUID, BukkitTask> activeParticleTasks = new HashMap<>();
|
||||
private final LegacyComponentSerializer legacy = LegacyComponentSerializer.legacyAmpersand();
|
||||
|
||||
@Override
|
||||
public void onEnable() {
|
||||
saveDefaultConfig();
|
||||
Bukkit.getPluginManager().registerEvents(new FirstJoinListener(this), this);
|
||||
|
||||
if (getCommand("dirtjoin") != null) {
|
||||
getCommand("dirtjoin").setExecutor(this);
|
||||
getCommand("dirtjoin").setTabCompleter(this);
|
||||
}
|
||||
|
||||
getLogger().info("DirtJoin enabled.");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDisable() {
|
||||
for (BukkitTask task : activeParticleTasks.values()) {
|
||||
if (task != null) {
|
||||
task.cancel();
|
||||
}
|
||||
}
|
||||
activeParticleTasks.clear();
|
||||
}
|
||||
|
||||
public void runFirstJoinEffects(Player player) {
|
||||
FileConfiguration config = getConfig();
|
||||
|
||||
if (!config.getBoolean("enabled", true)) {
|
||||
return;
|
||||
}
|
||||
|
||||
long delay = config.getLong("delay.join-effect-start-ticks", 20L);
|
||||
|
||||
Bukkit.getScheduler().runTaskLater(this, () -> {
|
||||
if (!player.isOnline()) {
|
||||
return;
|
||||
}
|
||||
|
||||
handleBlindness(player);
|
||||
handleSound(player);
|
||||
handleTitle(player);
|
||||
handleParticles(player);
|
||||
}, delay);
|
||||
}
|
||||
|
||||
public void runFirstJoinEffectsNow(Player player) {
|
||||
FileConfiguration config = getConfig();
|
||||
|
||||
if (!config.getBoolean("enabled", true)) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!player.isOnline()) {
|
||||
return;
|
||||
}
|
||||
|
||||
handleBlindness(player);
|
||||
handleSound(player);
|
||||
handleTitle(player);
|
||||
handleParticles(player);
|
||||
}
|
||||
|
||||
private void handleBlindness(Player player) {
|
||||
FileConfiguration config = getConfig();
|
||||
if (!config.getBoolean("blindness.enabled", true)) {
|
||||
return;
|
||||
}
|
||||
|
||||
int duration = config.getInt("blindness.duration-ticks", 40);
|
||||
int amplifier = config.getInt("blindness.amplifier", 0);
|
||||
boolean ambient = config.getBoolean("blindness.ambient", false);
|
||||
boolean particles = config.getBoolean("blindness.particles", false);
|
||||
boolean icon = config.getBoolean("blindness.icon", false);
|
||||
|
||||
player.addPotionEffect(new PotionEffect(
|
||||
PotionEffectType.BLINDNESS,
|
||||
duration,
|
||||
amplifier,
|
||||
ambient,
|
||||
particles,
|
||||
icon
|
||||
));
|
||||
}
|
||||
|
||||
private void handleSound(Player player) {
|
||||
FileConfiguration config = getConfig();
|
||||
if (!config.getBoolean("sound.enabled", true)) {
|
||||
return;
|
||||
}
|
||||
|
||||
String soundName = config.getString("sound.name", "entity.ender_dragon.death");
|
||||
float volume = (float) config.getDouble("sound.volume", 0.7);
|
||||
float pitch = (float) config.getDouble("sound.pitch", 1.2);
|
||||
|
||||
try {
|
||||
Sound sound = Registry.SOUNDS.get(NamespacedKey.minecraft(soundName.toLowerCase(Locale.ROOT)));
|
||||
if (sound != null) {
|
||||
player.playSound(player.getLocation(), sound, SoundCategory.MASTER, volume, pitch);
|
||||
} else {
|
||||
player.playSound(player.getLocation(), soundName, SoundCategory.MASTER, volume, pitch);
|
||||
}
|
||||
} catch (Exception ex) {
|
||||
getLogger().warning("Invalid sound in config: " + soundName);
|
||||
}
|
||||
}
|
||||
|
||||
private void handleTitle(Player player) {
|
||||
FileConfiguration config = getConfig();
|
||||
if (!config.getBoolean("title.enabled", true)) {
|
||||
return;
|
||||
}
|
||||
|
||||
int fadeIn = config.getInt("title.fade-in-ticks", 10);
|
||||
int stay = config.getInt("title.stay-ticks", 40);
|
||||
int fadeOut = config.getInt("title.fade-out-ticks", 10);
|
||||
|
||||
String main = config.getString("title.main", "&6Welcome to Dirtbag MC");
|
||||
String sub = config.getString("title.sub", "&eStart Your Grind");
|
||||
|
||||
player.showTitle(net.kyori.adventure.title.Title.title(
|
||||
legacy.deserialize(main),
|
||||
legacy.deserialize(sub),
|
||||
net.kyori.adventure.title.Title.Times.times(
|
||||
Duration.ofMillis(fadeIn * 50L),
|
||||
Duration.ofMillis(stay * 50L),
|
||||
Duration.ofMillis(fadeOut * 50L)
|
||||
)
|
||||
));
|
||||
}
|
||||
|
||||
private void handleParticles(Player player) {
|
||||
FileConfiguration config = getConfig();
|
||||
if (!config.getBoolean("particles.enabled", true)) {
|
||||
return;
|
||||
}
|
||||
|
||||
final Particle particle;
|
||||
try {
|
||||
particle = Particle.valueOf(config.getString("particles.type", "PORTAL").toUpperCase(Locale.ROOT));
|
||||
} catch (Exception ex) {
|
||||
getLogger().warning("Invalid particle in config. Using PORTAL.");
|
||||
return;
|
||||
}
|
||||
|
||||
int durationTicks = config.getInt("particles.duration-ticks", 60);
|
||||
long intervalTicks = config.getLong("particles.interval-ticks", 5L);
|
||||
int count = config.getInt("particles.count-per-burst", 40);
|
||||
double offsetX = config.getDouble("particles.offset-x", 1.0);
|
||||
double offsetY = config.getDouble("particles.offset-y", 1.0);
|
||||
double offsetZ = config.getDouble("particles.offset-z", 1.0);
|
||||
double extra = config.getDouble("particles.extra", 0.2);
|
||||
|
||||
UUID uuid = player.getUniqueId();
|
||||
|
||||
BukkitTask oldTask = activeParticleTasks.remove(uuid);
|
||||
if (oldTask != null) {
|
||||
oldTask.cancel();
|
||||
}
|
||||
|
||||
long repeats = Math.max(1L, durationTicks / Math.max(1L, intervalTicks));
|
||||
final long[] ran = {0};
|
||||
|
||||
BukkitTask task = Bukkit.getScheduler().runTaskTimer(this, () -> {
|
||||
if (!player.isOnline()) {
|
||||
BukkitTask active = activeParticleTasks.remove(uuid);
|
||||
if (active != null) {
|
||||
active.cancel();
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
Location loc = player.getLocation().clone().add(0, 1, 0);
|
||||
player.getWorld().spawnParticle(particle, loc, count, offsetX, offsetY, offsetZ, extra);
|
||||
|
||||
ran[0]++;
|
||||
if (ran[0] >= repeats) {
|
||||
BukkitTask active = activeParticleTasks.remove(uuid);
|
||||
if (active != null) {
|
||||
active.cancel();
|
||||
}
|
||||
}
|
||||
}, 0L, intervalTicks);
|
||||
|
||||
activeParticleTasks.put(uuid, task);
|
||||
}
|
||||
|
||||
public Component color(String text) {
|
||||
return legacy.deserialize(text == null ? "" : text);
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
|
||||
if (args.length == 0) {
|
||||
sender.sendMessage(color("&eUsage: /dirtjoin <reload|test>"));
|
||||
return true;
|
||||
}
|
||||
|
||||
if (args[0].equalsIgnoreCase("reload")) {
|
||||
if (!sender.hasPermission("dirtjoin.reload")) {
|
||||
sender.sendMessage(color(getConfig().getString("messages.no-permission", "&cYou do not have permission.")));
|
||||
return true;
|
||||
}
|
||||
|
||||
reloadConfig();
|
||||
sender.sendMessage(color(getConfig().getString("messages.reloaded", "&aDirtJoin config reloaded.")));
|
||||
return true;
|
||||
}
|
||||
|
||||
if (args[0].equalsIgnoreCase("test")) {
|
||||
if (!sender.hasPermission("dirtjoin.test")) {
|
||||
sender.sendMessage(color(getConfig().getString("messages.no-permission", "&cYou do not have permission.")));
|
||||
return true;
|
||||
}
|
||||
|
||||
if (!(sender instanceof Player player)) {
|
||||
sender.sendMessage(color("&cOnly players can use /dirtjoin test."));
|
||||
return true;
|
||||
}
|
||||
|
||||
runFirstJoinEffectsNow(player);
|
||||
sender.sendMessage(color("&aTriggered DirtJoin effects on yourself."));
|
||||
return true;
|
||||
}
|
||||
|
||||
sender.sendMessage(color("&eUsage: /dirtjoin <reload|test>"));
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<String> onTabComplete(CommandSender sender, Command command, String alias, String[] args) {
|
||||
List<String> completions = new ArrayList<>();
|
||||
|
||||
if (args.length == 1) {
|
||||
if ("reload".startsWith(args[0].toLowerCase(Locale.ROOT))) {
|
||||
completions.add("reload");
|
||||
}
|
||||
if ("test".startsWith(args[0].toLowerCase(Locale.ROOT))) {
|
||||
completions.add("test");
|
||||
}
|
||||
}
|
||||
|
||||
return completions;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,30 @@
|
||||
package com.dirtbagmc.dirtjoin;
|
||||
|
||||
import org.bukkit.configuration.file.FileConfiguration;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.player.PlayerJoinEvent;
|
||||
|
||||
public class FirstJoinListener implements Listener {
|
||||
|
||||
private final DirtJoinPlugin plugin;
|
||||
|
||||
public FirstJoinListener(DirtJoinPlugin plugin) {
|
||||
this.plugin = plugin;
|
||||
}
|
||||
|
||||
@EventHandler
|
||||
public void onJoin(PlayerJoinEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
FileConfiguration config = plugin.getConfig();
|
||||
|
||||
boolean firstJoinOnly = config.getBoolean("first-join-only", true);
|
||||
|
||||
if (firstJoinOnly && player.hasPlayedBefore()) {
|
||||
return;
|
||||
}
|
||||
|
||||
plugin.runFirstJoinEffects(player);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,43 @@
|
||||
enabled: true
|
||||
|
||||
first-join-only: true
|
||||
|
||||
title:
|
||||
enabled: true
|
||||
fade-in-ticks: 10
|
||||
stay-ticks: 40
|
||||
fade-out-ticks: 10
|
||||
main: "&6Welcome to Dirtbag MC"
|
||||
sub: "&eStart Your Grind"
|
||||
|
||||
blindness:
|
||||
enabled: true
|
||||
duration-ticks: 40
|
||||
amplifier: 0
|
||||
ambient: false
|
||||
particles: false
|
||||
icon: false
|
||||
|
||||
sound:
|
||||
enabled: true
|
||||
name: "entity.ender_dragon.death"
|
||||
volume: 0.7
|
||||
pitch: 1.2
|
||||
|
||||
particles:
|
||||
enabled: true
|
||||
type: "portal"
|
||||
duration-ticks: 60
|
||||
interval-ticks: 5
|
||||
count-per-burst: 40
|
||||
offset-x: 1.0
|
||||
offset-y: 1.0
|
||||
offset-z: 1.0
|
||||
extra: 0.2
|
||||
|
||||
delay:
|
||||
join-effect-start-ticks: 20
|
||||
|
||||
messages:
|
||||
no-permission: "&cYou do not have permission."
|
||||
reloaded: "&aDirtJoin config reloaded."
|
||||
@@ -0,0 +1,23 @@
|
||||
name: DirtJoin
|
||||
version: 1.0-SNAPSHOT
|
||||
main: com.dirtbagmc.dirtjoin.DirtJoinPlugin
|
||||
api-version: '1.21'
|
||||
author: DirtbagMC
|
||||
description: First join effects plugin
|
||||
|
||||
commands:
|
||||
dirtjoin:
|
||||
description: Main DirtJoin command
|
||||
usage: /dirtjoin <reload|test>
|
||||
permission: dirtjoin.use
|
||||
|
||||
permissions:
|
||||
dirtjoin.use:
|
||||
description: Allows use of DirtJoin commands
|
||||
default: op
|
||||
dirtjoin.reload:
|
||||
description: Allows reloading DirtJoin config
|
||||
default: op
|
||||
dirtjoin.test:
|
||||
description: Allows testing DirtJoin effects
|
||||
default: op
|
||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
@@ -0,0 +1,43 @@
|
||||
enabled: true
|
||||
|
||||
first-join-only: true
|
||||
|
||||
title:
|
||||
enabled: true
|
||||
fade-in-ticks: 10
|
||||
stay-ticks: 40
|
||||
fade-out-ticks: 10
|
||||
main: "&6Welcome to Dirtbag MC"
|
||||
sub: "&eStart Your Grind"
|
||||
|
||||
blindness:
|
||||
enabled: true
|
||||
duration-ticks: 40
|
||||
amplifier: 0
|
||||
ambient: false
|
||||
particles: false
|
||||
icon: false
|
||||
|
||||
sound:
|
||||
enabled: true
|
||||
name: "entity.ender_dragon.death"
|
||||
volume: 0.7
|
||||
pitch: 1.2
|
||||
|
||||
particles:
|
||||
enabled: true
|
||||
type: "portal"
|
||||
duration-ticks: 60
|
||||
interval-ticks: 5
|
||||
count-per-burst: 40
|
||||
offset-x: 1.0
|
||||
offset-y: 1.0
|
||||
offset-z: 1.0
|
||||
extra: 0.2
|
||||
|
||||
delay:
|
||||
join-effect-start-ticks: 20
|
||||
|
||||
messages:
|
||||
no-permission: "&cYou do not have permission."
|
||||
reloaded: "&aDirtJoin config reloaded."
|
||||
@@ -0,0 +1,23 @@
|
||||
name: DirtJoin
|
||||
version: 1.0-SNAPSHOT
|
||||
main: com.dirtbagmc.dirtjoin.DirtJoinPlugin
|
||||
api-version: '1.21'
|
||||
author: DirtbagMC
|
||||
description: First join effects plugin
|
||||
|
||||
commands:
|
||||
dirtjoin:
|
||||
description: Main DirtJoin command
|
||||
usage: /dirtjoin <reload|test>
|
||||
permission: dirtjoin.use
|
||||
|
||||
permissions:
|
||||
dirtjoin.use:
|
||||
description: Allows use of DirtJoin commands
|
||||
default: op
|
||||
dirtjoin.reload:
|
||||
description: Allows reloading DirtJoin config
|
||||
default: op
|
||||
dirtjoin.test:
|
||||
description: Allows testing DirtJoin effects
|
||||
default: op
|
||||
@@ -0,0 +1,5 @@
|
||||
#Generated by Maven
|
||||
#Sat Jun 13 16:41:36 EDT 2026
|
||||
artifactId=DirtJoin
|
||||
groupId=com.dirtbagmc
|
||||
version=1.0-SNAPSHOT
|
||||
@@ -0,0 +1,2 @@
|
||||
com/dirtbagmc/dirtjoin/FirstJoinListener.class
|
||||
com/dirtbagmc/dirtjoin/DirtJoinPlugin.class
|
||||
@@ -0,0 +1,2 @@
|
||||
/home/bitnix/Desktop/DirtJoin/src/main/java/com/dirtbagmc/dirtjoin/DirtJoinPlugin.java
|
||||
/home/bitnix/Desktop/DirtJoin/src/main/java/com/dirtbagmc/dirtjoin/FirstJoinListener.java
|
||||
Reference in New Issue
Block a user