mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-26 15:13:45 +01:00 
			
		
		
		
	Compare commits
	
		
			42 Commits
		
	
	
		
			world-stat
			...
			fix/4669
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | b36dab6301 | ||
|   | f020a6c6da | ||
|   | d7e158747e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 4d64ea83ec | ||
|   | 7ab334562c | ||
|   | fe1ef36f7e | ||
|   | 70bc02985f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 3ec7e992a3 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 9acaa9c554 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | e132c01331 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 24e4e51884 | ||
|   | 84ec090df1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6c6ea1c1b4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 97989face1 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f471c02330 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 94322d5982 | ||
|   | 6cbb894249 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6f0fa19601 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0b692459e6 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 0d410ed869 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 711fba0b2a | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 671a27fa6f | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 03de685dc4 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | f616885206 | ||
|   | 7da4eb1ab5 | ||
|   | 629646ab06 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 74a1a1f954 | ||
|   | aa44078018 | ||
|   | bfbf406418 | ||
|   | 2accedf264 | ||
|   | 6ef0d58480 | ||
|   | fbf4a638b4 | ||
|   | 9abfa21078 | ||
|   | b84599b4b3 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 058983cdd5 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 6ba3694121 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 8e8e31b80e | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | da2e66c1f8 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | d5d6fcb859 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 96f73331f9 | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 020947d90c | ||
| ![renovate[bot]](/assets/img/avatar_default.png)  | 7dbd0bcff8 | 
							
								
								
									
										3
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.github/renovate.json
									
									
									
									
										vendored
									
									
								
							| @@ -2,7 +2,8 @@ | |||||||
|   "$schema": "https://docs.renovatebot.com/renovate-schema.json", |   "$schema": "https://docs.renovatebot.com/renovate-schema.json", | ||||||
|   "extends": [ |   "extends": [ | ||||||
|     "config:recommended", |     "config:recommended", | ||||||
|     ":semanticCommitsDisabled" |     ":semanticCommitsDisabled", | ||||||
|  |     "schedule:earlyMondays" | ||||||
|   ], |   ], | ||||||
|   "automerge": true, |   "automerge": true, | ||||||
|   "labels": [ |   "labels": [ | ||||||
|   | |||||||
| @@ -252,6 +252,11 @@ public final class BukkitPlatform extends JavaPlugin implements Listener, PlotPl | |||||||
|         return Bukkit.getVersion(); |         return Bukkit.getVersion(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public @NonNull String serverBrand() { | ||||||
|  |         return Bukkit.getName(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     @SuppressWarnings("deprecation") // Paper deprecation |     @SuppressWarnings("deprecation") // Paper deprecation | ||||||
|     public void onEnable() { |     public void onEnable() { | ||||||
|   | |||||||
| @@ -28,7 +28,6 @@ import com.plotsquared.core.plot.flag.implementations.CopperOxideFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | import com.plotsquared.core.plot.flag.implementations.MiscInteractFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.SculkSensorInteractFlag; | import com.plotsquared.core.plot.flag.implementations.SculkSensorInteractFlag; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import org.bukkit.Material; |  | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.entity.Entity; | import org.bukkit.entity.Entity; | ||||||
| import org.bukkit.entity.Item; | import org.bukkit.entity.Item; | ||||||
| @@ -42,31 +41,11 @@ import org.bukkit.event.block.BlockReceiveGameEvent; | |||||||
|  |  | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Objects; | import java.util.Objects; | ||||||
| import java.util.Set; |  | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
| @SuppressWarnings("unused") | @SuppressWarnings("unused") | ||||||
| public class BlockEventListener117 implements Listener { | public class BlockEventListener117 implements Listener { | ||||||
|  |  | ||||||
|     private static final Set<Material> COPPER_OXIDIZING = Set.of( |  | ||||||
|             Material.COPPER_BLOCK, |  | ||||||
|             Material.EXPOSED_COPPER, |  | ||||||
|             Material.WEATHERED_COPPER, |  | ||||||
|             Material.OXIDIZED_COPPER, |  | ||||||
|             Material.CUT_COPPER, |  | ||||||
|             Material.EXPOSED_CUT_COPPER, |  | ||||||
|             Material.WEATHERED_CUT_COPPER, |  | ||||||
|             Material.OXIDIZED_CUT_COPPER, |  | ||||||
|             Material.CUT_COPPER_STAIRS, |  | ||||||
|             Material.EXPOSED_CUT_COPPER_STAIRS, |  | ||||||
|             Material.WEATHERED_CUT_COPPER_STAIRS, |  | ||||||
|             Material.OXIDIZED_CUT_COPPER_STAIRS, |  | ||||||
|             Material.CUT_COPPER_SLAB, |  | ||||||
|             Material.EXPOSED_CUT_COPPER_SLAB, |  | ||||||
|             Material.WEATHERED_CUT_COPPER_SLAB, |  | ||||||
|             Material.OXIDIZED_CUT_COPPER_SLAB |  | ||||||
|     ); |  | ||||||
|  |  | ||||||
|     @Inject |     @Inject | ||||||
|     public BlockEventListener117() { |     public BlockEventListener117() { | ||||||
|     } |     } | ||||||
| @@ -184,7 +163,7 @@ public class BlockEventListener117 implements Listener { | |||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         if (COPPER_OXIDIZING.contains(event.getNewState().getType())) { |         if (event.getNewState().getType().name().contains("COPPER")) { | ||||||
|             if (!plot.getFlag(CopperOxideFlag.class)) { |             if (!plot.getFlag(CopperOxideFlag.class)) { | ||||||
|                 plot.debug("Copper could not oxide because copper-oxide = false"); |                 plot.debug("Copper could not oxide because copper-oxide = false"); | ||||||
|                 event.setCancelled(true); |                 event.setCancelled(true); | ||||||
|   | |||||||
| @@ -29,6 +29,7 @@ import com.destroystokyo.paper.event.player.PlayerLaunchProjectileEvent; | |||||||
| import com.destroystokyo.paper.event.server.AsyncTabCompleteEvent; | import com.destroystokyo.paper.event.server.AsyncTabCompleteEvent; | ||||||
| import com.google.inject.Inject; | import com.google.inject.Inject; | ||||||
| import com.plotsquared.bukkit.util.BukkitUtil; | import com.plotsquared.bukkit.util.BukkitUtil; | ||||||
|  | import com.plotsquared.core.PlotSquared; | ||||||
| import com.plotsquared.core.command.Command; | import com.plotsquared.core.command.Command; | ||||||
| import com.plotsquared.core.command.MainCommand; | import com.plotsquared.core.command.MainCommand; | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| @@ -38,6 +39,7 @@ import com.plotsquared.core.permissions.Permission; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import com.plotsquared.core.plot.Plot; | import com.plotsquared.core.plot.Plot; | ||||||
| import com.plotsquared.core.plot.PlotArea; | import com.plotsquared.core.plot.PlotArea; | ||||||
|  | import com.plotsquared.core.plot.PlotAreaType; | ||||||
| import com.plotsquared.core.plot.flag.FlagContainer; | import com.plotsquared.core.plot.flag.FlagContainer; | ||||||
| import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; | import com.plotsquared.core.plot.flag.implementations.BeaconEffectsFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.DoneFlag; | import com.plotsquared.core.plot.flag.implementations.DoneFlag; | ||||||
| @@ -48,6 +50,7 @@ import com.plotsquared.core.plot.flag.types.BooleanFlag; | |||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.PlotFlagUtil; | import com.plotsquared.core.util.PlotFlagUtil; | ||||||
| import io.papermc.paper.event.entity.EntityMoveEvent; | import io.papermc.paper.event.entity.EntityMoveEvent; | ||||||
|  | import io.papermc.paper.event.world.StructuresLocateEvent; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| @@ -458,6 +461,21 @@ public class PaperListener implements Listener { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Don't let the server die when populating cartographers (villager offering maps) in classic plot worlds | ||||||
|  |      * (as those don't generate POIs) | ||||||
|  |      */ | ||||||
|  |     @EventHandler(ignoreCancelled = true, priority = EventPriority.HIGHEST) | ||||||
|  |     public void onStructuresLocate(StructuresLocateEvent event) { | ||||||
|  |         if (!PlotSquared.get().getPlotAreaManager().hasPlotArea(event.getWorld().getName())) { | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  |         final PlotArea area = PlotSquared.get().getPlotAreaManager().getPlotAreaByString(event.getWorld().getName()); | ||||||
|  |         if (area != null && area.getType() == PlotAreaType.NORMAL) { | ||||||
|  |             event.setCancelled(true); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|     private boolean getBooleanFlagValue( |     private boolean getBooleanFlagValue( | ||||||
|             @NonNull FlagContainer container, |             @NonNull FlagContainer container, | ||||||
|             @NonNull Class<? extends BooleanFlag<?>> flagClass, |             @NonNull Class<? extends BooleanFlag<?>> flagClass, | ||||||
|   | |||||||
| @@ -64,9 +64,11 @@ import com.plotsquared.core.plot.flag.implementations.PreventCreativeCopyFlag; | |||||||
| import com.plotsquared.core.plot.flag.implementations.TamedInteractFlag; | import com.plotsquared.core.plot.flag.implementations.TamedInteractFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.TileDropFlag; | import com.plotsquared.core.plot.flag.implementations.TileDropFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.UntrustedVisitFlag; | import com.plotsquared.core.plot.flag.implementations.UntrustedVisitFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.implementations.UseFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleBreakFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleBreakFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VehicleUseFlag; | import com.plotsquared.core.plot.flag.implementations.VehicleUseFlag; | ||||||
| import com.plotsquared.core.plot.flag.implementations.VillagerInteractFlag; | import com.plotsquared.core.plot.flag.implementations.VillagerInteractFlag; | ||||||
|  | import com.plotsquared.core.plot.flag.types.BlockTypeWrapper; | ||||||
| import com.plotsquared.core.plot.world.PlotAreaManager; | import com.plotsquared.core.plot.world.PlotAreaManager; | ||||||
| import com.plotsquared.core.util.EventDispatcher; | import com.plotsquared.core.util.EventDispatcher; | ||||||
| import com.plotsquared.core.util.MathMan; | import com.plotsquared.core.util.MathMan; | ||||||
| @@ -78,6 +80,7 @@ import com.plotsquared.core.util.task.TaskTime; | |||||||
| import com.sk89q.worldedit.WorldEdit; | import com.sk89q.worldedit.WorldEdit; | ||||||
| import com.sk89q.worldedit.bukkit.BukkitAdapter; | import com.sk89q.worldedit.bukkit.BukkitAdapter; | ||||||
| import com.sk89q.worldedit.world.block.BlockType; | import com.sk89q.worldedit.world.block.BlockType; | ||||||
|  | import com.sk89q.worldedit.world.block.BlockTypes; | ||||||
| import io.papermc.lib.PaperLib; | import io.papermc.lib.PaperLib; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
| @@ -88,10 +91,8 @@ import org.bukkit.Bukkit; | |||||||
| import org.bukkit.FluidCollisionMode; | import org.bukkit.FluidCollisionMode; | ||||||
| import org.bukkit.Material; | import org.bukkit.Material; | ||||||
| import org.bukkit.block.Block; | import org.bukkit.block.Block; | ||||||
| import org.bukkit.block.BlockFace; |  | ||||||
| import org.bukkit.block.BlockState; | import org.bukkit.block.BlockState; | ||||||
| import org.bukkit.block.Sign; | import org.bukkit.block.Sign; | ||||||
| import org.bukkit.block.data.Waterlogged; |  | ||||||
| import org.bukkit.command.PluginCommand; | import org.bukkit.command.PluginCommand; | ||||||
| import org.bukkit.entity.ArmorStand; | import org.bukkit.entity.ArmorStand; | ||||||
| import org.bukkit.entity.Boat; | import org.bukkit.entity.Boat; | ||||||
| @@ -154,9 +155,11 @@ import org.bukkit.util.Vector; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| import java.lang.reflect.Field; | import java.lang.reflect.Field; | ||||||
|  | import java.util.Collections; | ||||||
| import java.util.HashSet; | import java.util.HashSet; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
|  | import java.util.Optional; | ||||||
| import java.util.Set; | import java.util.Set; | ||||||
| import java.util.UUID; | import java.util.UUID; | ||||||
|  |  | ||||||
| @@ -181,6 +184,7 @@ public class PlayerEventListener implements Listener { | |||||||
|             Material.WRITTEN_BOOK |             Material.WRITTEN_BOOK | ||||||
|     ); |     ); | ||||||
|     private static final Set<String> DYES; |     private static final Set<String> DYES; | ||||||
|  |  | ||||||
|     static { |     static { | ||||||
|         Set<String> mutableDyes = new HashSet<>(Set.of( |         Set<String> mutableDyes = new HashSet<>(Set.of( | ||||||
|                 "WHITE_DYE", |                 "WHITE_DYE", | ||||||
| @@ -215,7 +219,7 @@ public class PlayerEventListener implements Listener { | |||||||
|         // "temporary" fix for https://hub.spigotmc.org/jira/browse/SPIGOT-7813 |         // "temporary" fix for https://hub.spigotmc.org/jira/browse/SPIGOT-7813 | ||||||
|         // can (and should) be removed when 1.21 support is dropped |         // can (and should) be removed when 1.21 support is dropped | ||||||
|         // List of all interactable 1.21 materials |         // List of all interactable 1.21 materials | ||||||
|         INTERACTABLE_MATERIALS = Material.CHEST.isInteractable() ? null :  Set.of( |         INTERACTABLE_MATERIALS = Material.CHEST.isInteractable() ? null : Set.of( | ||||||
|                 "REDSTONE_ORE", "DEEPSLATE_REDSTONE_ORE", "CHISELED_BOOKSHELF", "DECORATED_POT", "CHEST", "CRAFTING_TABLE", |                 "REDSTONE_ORE", "DEEPSLATE_REDSTONE_ORE", "CHISELED_BOOKSHELF", "DECORATED_POT", "CHEST", "CRAFTING_TABLE", | ||||||
|                 "FURNACE", "JUKEBOX", "OAK_FENCE", "SPRUCE_FENCE", "BIRCH_FENCE", "JUNGLE_FENCE", "ACACIA_FENCE", "CHERRY_FENCE", |                 "FURNACE", "JUKEBOX", "OAK_FENCE", "SPRUCE_FENCE", "BIRCH_FENCE", "JUNGLE_FENCE", "ACACIA_FENCE", "CHERRY_FENCE", | ||||||
|                 "DARK_OAK_FENCE", "MANGROVE_FENCE", "BAMBOO_FENCE", "CRIMSON_FENCE", "WARPED_FENCE", "PUMPKIN", |                 "DARK_OAK_FENCE", "MANGROVE_FENCE", "BAMBOO_FENCE", "CRIMSON_FENCE", "WARPED_FENCE", "PUMPKIN", | ||||||
| @@ -533,12 +537,14 @@ public class PlayerEventListener implements Listener { | |||||||
|         // Delayed |         // Delayed | ||||||
|  |  | ||||||
|         // Async |         // Async | ||||||
|         TaskManager.runTaskLaterAsync(() -> { |         TaskManager.runTaskLaterAsync( | ||||||
|             if (!player.hasPlayedBefore() && player.isOnline()) { |                 () -> { | ||||||
|                 player.saveData(); |                     if (!player.hasPlayedBefore() && player.isOnline()) { | ||||||
|             } |                         player.saveData(); | ||||||
|             this.eventDispatcher.doJoinTask(pp); |                     } | ||||||
|         }, TaskTime.seconds(1L)); |                     this.eventDispatcher.doJoinTask(pp); | ||||||
|  |                 }, TaskTime.seconds(1L) | ||||||
|  |         ); | ||||||
|  |  | ||||||
|         if (pp.hasPermission(Permission.PERMISSION_ADMIN_UPDATE_NOTIFICATION.toString()) && Settings.Enabled_Components.UPDATE_NOTIFICATIONS |         if (pp.hasPermission(Permission.PERMISSION_ADMIN_UPDATE_NOTIFICATION.toString()) && Settings.Enabled_Components.UPDATE_NOTIFICATIONS | ||||||
|                 && PremiumVerification.isPremium() && UpdateUtility.hasUpdate) { |                 && PremiumVerification.isPremium() && UpdateUtility.hasUpdate) { | ||||||
| @@ -599,8 +605,14 @@ public class PlayerEventListener implements Listener { | |||||||
|                     // to is identical to the plot's home location, and untrusted-visit is true |                     // to is identical to the plot's home location, and untrusted-visit is true | ||||||
|                     // i.e. untrusted-visit can override deny-teleport |                     // i.e. untrusted-visit can override deny-teleport | ||||||
|                     // this is acceptable, because otherwise it wouldn't make sense to have both flags set |                     // this is acceptable, because otherwise it wouldn't make sense to have both flags set | ||||||
|                     if (result || (plot.getFlag(UntrustedVisitFlag.class) && plot.getHomeSynchronous().equals(BukkitUtil.adaptComplete(to)))) { |                     if (result || (plot.getFlag(UntrustedVisitFlag.class) && plot | ||||||
|                         plotListener.plotEntry(pp, plot); |                             .getHomeSynchronous() | ||||||
|  |                             .equals(BukkitUtil.adaptComplete(to)))) { | ||||||
|  |                         // returns false if the player is not allowed to enter the plot (if they are denied, for example) | ||||||
|  |                         // don't let the move event cancel the entry after teleport, but rather catch and cancel early (#4647) | ||||||
|  |                         if (!plotListener.plotEntry(pp, plot)) { | ||||||
|  |                             event.setCancelled(true); | ||||||
|  |                         } | ||||||
|                     } else { |                     } else { | ||||||
|                         pp.sendMessage( |                         pp.sendMessage( | ||||||
|                                 TranslatableCaption.of("deny.no_enter"), |                                 TranslatableCaption.of("deny.no_enter"), | ||||||
| @@ -939,12 +951,15 @@ public class PlayerEventListener implements Listener { | |||||||
|         builder.tag("plot_id", Tag.inserting(Component.text(id.toString()))); |         builder.tag("plot_id", Tag.inserting(Component.text(id.toString()))); | ||||||
|         builder.tag("sender", Tag.inserting(Component.text(sender))); |         builder.tag("sender", Tag.inserting(Component.text(sender))); | ||||||
|         if (plotPlayer.hasPermission("plots.chat.color")) { |         if (plotPlayer.hasPermission("plots.chat.color")) { | ||||||
|             builder.tag("msg", Tag.inserting(MiniMessage.miniMessage().deserialize( |             builder.tag( | ||||||
|                     message, |                     "msg", Tag.inserting(MiniMessage.miniMessage().deserialize( | ||||||
|                     TagResolver.resolver(StandardTags.color(), StandardTags.gradient(), |                             message, | ||||||
|                             StandardTags.rainbow(), StandardTags.decorations() |                             TagResolver.resolver( | ||||||
|                     ) |                                     StandardTags.color(), StandardTags.gradient(), | ||||||
|             ))); |                                     StandardTags.rainbow(), StandardTags.decorations() | ||||||
|  |                             ) | ||||||
|  |                     )) | ||||||
|  |             ); | ||||||
|         } else { |         } else { | ||||||
|             builder.tag("msg", Tag.inserting(Component.text(message))); |             builder.tag("msg", Tag.inserting(Component.text(message))); | ||||||
|         } |         } | ||||||
| @@ -1253,7 +1268,9 @@ public class PlayerEventListener implements Listener { | |||||||
|                 eventType = PlayerBlockEventType.INTERACT_BLOCK; |                 eventType = PlayerBlockEventType.INTERACT_BLOCK; | ||||||
|                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); |                 blocktype1 = BukkitAdapter.asBlockType(block.getType()); | ||||||
|  |  | ||||||
|                 if (INTERACTABLE_MATERIALS != null ? INTERACTABLE_MATERIALS.contains(blockType.name()) : blockType.isInteractable()) { |                 if (INTERACTABLE_MATERIALS != null | ||||||
|  |                         ? INTERACTABLE_MATERIALS.contains(blockType.name()) | ||||||
|  |                         : blockType.isInteractable()) { | ||||||
|                     if (!player.isSneaking()) { |                     if (!player.isSneaking()) { | ||||||
|                         break; |                         break; | ||||||
|                     } |                     } | ||||||
| @@ -1271,7 +1288,7 @@ public class PlayerEventListener implements Listener { | |||||||
|                 // in the following, lb needs to have the material of the item in hand i.e. type |                 // in the following, lb needs to have the material of the item in hand i.e. type | ||||||
|                 switch (type.toString()) { |                 switch (type.toString()) { | ||||||
|                     case "REDSTONE", "STRING", "PUMPKIN_SEEDS", "MELON_SEEDS", "COCOA_BEANS", "WHEAT_SEEDS", "BEETROOT_SEEDS", |                     case "REDSTONE", "STRING", "PUMPKIN_SEEDS", "MELON_SEEDS", "COCOA_BEANS", "WHEAT_SEEDS", "BEETROOT_SEEDS", | ||||||
|                             "SWEET_BERRIES", "GLOW_BERRIES" -> { |                          "SWEET_BERRIES", "GLOW_BERRIES" -> { | ||||||
|                         return; |                         return; | ||||||
|                     } |                     } | ||||||
|                     default -> { |                     default -> { | ||||||
| @@ -1296,6 +1313,17 @@ public class PlayerEventListener implements Listener { | |||||||
|                     //Allow all players to eat while also allowing the block place event to be fired |                     //Allow all players to eat while also allowing the block place event to be fired | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|  |                 // Process creature spawning of armor stands & end crystals here if spawned by the player in order to be able to | ||||||
|  |                 // reset the player's hand item if spawning needs to be cancelled. | ||||||
|  |                 if (type == Material.ARMOR_STAND || type == Material.END_CRYSTAL) { | ||||||
|  |                     Plot plot = location.getOwnedPlotAbs(); | ||||||
|  |                     if (BukkitEntityUtil.checkEntity(type == Material.ARMOR_STAND ? EntityType.ARMOR_STAND : EntityType.ENDER_CRYSTAL, | ||||||
|  |                             plot)) { | ||||||
|  |                         event.setCancelled(true); | ||||||
|  |                         break; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 // Continue with normal place event checks | ||||||
|                 if (type == Material.ARMOR_STAND) { |                 if (type == Material.ARMOR_STAND) { | ||||||
|                     location = BukkitUtil.adapt(block.getRelative(event.getBlockFace()).getLocation()); |                     location = BukkitUtil.adapt(block.getRelative(event.getBlockFace()).getLocation()); | ||||||
|                     eventType = PlayerBlockEventType.PLACE_MISC; |                     eventType = PlayerBlockEventType.PLACE_MISC; | ||||||
| @@ -1370,22 +1398,7 @@ public class PlayerEventListener implements Listener { | |||||||
|  |  | ||||||
|     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) |     @EventHandler(priority = EventPriority.HIGHEST, ignoreCancelled = true) | ||||||
|     public void onBucketEmpty(PlayerBucketEmptyEvent event) { |     public void onBucketEmpty(PlayerBucketEmptyEvent event) { | ||||||
|         BlockFace bf = event.getBlockFace(); |         final Block block = event.getBlock(); | ||||||
|         // Note: a month after Bukkit 1.14.4 released, they added the API method |  | ||||||
|         // PlayerBucketEmptyEvent#getBlock(), which returns the block the |  | ||||||
|         // bucket contents is going to be placed at. Currently we determine this |  | ||||||
|         // block ourselves to retain compatibility with 1.13. |  | ||||||
|         final Block block; |  | ||||||
|         // if the block can be waterlogged, the event might waterlog the block |  | ||||||
|         // sometimes |  | ||||||
|         if (event.getBlockClicked().getBlockData() instanceof Waterlogged waterlogged |  | ||||||
|                 && !waterlogged.isWaterlogged() && event.getBucket() != Material.LAVA_BUCKET) { |  | ||||||
|             block = event.getBlockClicked(); |  | ||||||
|         } else { |  | ||||||
|             block = event.getBlockClicked().getLocation() |  | ||||||
|                     .add(bf.getModX(), bf.getModY(), bf.getModZ()) |  | ||||||
|                     .getBlock(); |  | ||||||
|         } |  | ||||||
|         Location location = BukkitUtil.adapt(block.getLocation()); |         Location location = BukkitUtil.adapt(block.getLocation()); | ||||||
|         PlotArea area = location.getPlotArea(); |         PlotArea area = location.getPlotArea(); | ||||||
|         if (area == null) { |         if (area == null) { | ||||||
| @@ -1393,6 +1406,16 @@ public class PlayerEventListener implements Listener { | |||||||
|         } |         } | ||||||
|         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); |         BukkitPlayer pp = BukkitUtil.adapt(event.getPlayer()); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|  |         final List<BlockTypeWrapper> use = | ||||||
|  |                 Optional.ofNullable(plot).map(p -> p.getFlag(UseFlag.class)).orElse(area.isRoadFlags() ? | ||||||
|  |                         area.getFlag(UseFlag.class) : Collections.emptyList()); | ||||||
|  |         BlockType type = BukkitAdapter.asBlockType(block.getType()); | ||||||
|  |         for (final BlockTypeWrapper blockTypeWrapper : use) { | ||||||
|  |             if (blockTypeWrapper.accepts(BlockTypes.AIR) || blockTypeWrapper | ||||||
|  |                     .accepts(type)) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (pp.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 return; |                 return; | ||||||
| @@ -1464,6 +1487,16 @@ public class PlayerEventListener implements Listener { | |||||||
|         Player player = event.getPlayer(); |         Player player = event.getPlayer(); | ||||||
|         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); |         BukkitPlayer plotPlayer = BukkitUtil.adapt(player); | ||||||
|         Plot plot = area.getPlot(location); |         Plot plot = area.getPlot(location); | ||||||
|  |         final List<BlockTypeWrapper> use = | ||||||
|  |                 Optional.ofNullable(plot).map(p -> p.getFlag(UseFlag.class)).orElse(area.isRoadFlags() ? | ||||||
|  |                         area.getFlag(UseFlag.class) : Collections.emptyList()); | ||||||
|  |         BlockType type = BukkitAdapter.asBlockType(blockClicked.getType()); | ||||||
|  |         for (final BlockTypeWrapper blockTypeWrapper : use) { | ||||||
|  |             if (blockTypeWrapper.accepts(BlockTypes.AIR) || blockTypeWrapper | ||||||
|  |                     .accepts(type)) { | ||||||
|  |                 return; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         if (plot == null) { |         if (plot == null) { | ||||||
|             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { |             if (plotPlayer.hasPermission(Permission.PERMISSION_ADMIN_BUILD_ROAD)) { | ||||||
|                 return; |                 return; | ||||||
|   | |||||||
| @@ -354,13 +354,17 @@ public class BukkitEntityUtil { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     public static boolean checkEntity(Entity entity, Plot plot) { |     public static boolean checkEntity(Entity entity, Plot plot) { | ||||||
|  |         return checkEntity(entity.getType(), plot); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public static boolean checkEntity(EntityType type, Plot plot) { | ||||||
|         if (plot == null || !plot.hasOwner() || plot.getFlags().isEmpty() && plot.getArea() |         if (plot == null || !plot.hasOwner() || plot.getFlags().isEmpty() && plot.getArea() | ||||||
|                 .getFlagContainer().getFlagMap().isEmpty()) { |                 .getFlagContainer().getFlagMap().isEmpty()) { | ||||||
|             return false; |             return false; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         final com.sk89q.worldedit.world.entity.EntityType entityType = |         final com.sk89q.worldedit.world.entity.EntityType entityType = | ||||||
|                 BukkitAdapter.adapt(entity.getType()); |                 BukkitAdapter.adapt(type); | ||||||
|  |  | ||||||
|         if (EntityCategories.PLAYER.contains(entityType)) { |         if (EntityCategories.PLAYER.contains(entityType)) { | ||||||
|             return false; |             return false; | ||||||
|   | |||||||
| @@ -120,6 +120,14 @@ public interface PlotPlatform<P> extends LocaleHolder { | |||||||
|      */ |      */ | ||||||
|     @NonNull String serverImplementation(); |     @NonNull String serverImplementation(); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Gets the server brand name | ||||||
|  |      * | ||||||
|  |      * @return server brand | ||||||
|  |      * @since 7.5.3 | ||||||
|  |      */ | ||||||
|  |     @NonNull String serverBrand(); | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Gets the native server code package prefix. |      * Gets the native server code package prefix. | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -24,6 +24,7 @@ import com.plotsquared.core.configuration.caption.TranslatableCaption; | |||||||
| import com.plotsquared.core.player.PlotPlayer; | import com.plotsquared.core.player.PlotPlayer; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.jetbrains.annotations.NotNull; | ||||||
|  |  | ||||||
| @@ -98,6 +99,14 @@ public enum CommandCategory implements Caption { | |||||||
|         return MiniMessage.miniMessage().deserialize(getComponent(localeHolder)); |         return MiniMessage.miniMessage().deserialize(getComponent(localeHolder)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public @NonNull Component toComponent( | ||||||
|  |             @NonNull final LocaleHolder localeHolder, | ||||||
|  |             final @NonNull TagResolver @NonNull ... tagResolvers | ||||||
|  |     ) { | ||||||
|  |         return MiniMessage.miniMessage().deserialize(getComponent(localeHolder)); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * Checks if a player has access to this command category |      * Checks if a player has access to this command category | ||||||
|      * |      * | ||||||
|   | |||||||
| @@ -86,7 +86,8 @@ public class DebugPaste extends SubCommand { | |||||||
|                 b.append("# WorldEdit implementation:\n"); |                 b.append("# WorldEdit implementation:\n"); | ||||||
|                 b.append(PlotSquared.platform().worldEditImplementations()).append("\n\n"); |                 b.append(PlotSquared.platform().worldEditImplementations()).append("\n\n"); | ||||||
|                 b.append("# Server Information\n"); |                 b.append("# Server Information\n"); | ||||||
|                 b.append("Server Version: ").append(PlotSquared.platform().serverImplementation()) |                 b.append("Server Version: ").append(PlotSquared.platform().serverBrand()).append(": ") | ||||||
|  |                         .append(PlotSquared.platform().serverImplementation()).append("\n") | ||||||
|                         .append("\n"); |                         .append("\n"); | ||||||
|                 b.append("online_mode: ").append(!Settings.UUID.OFFLINE).append(';') |                 b.append("online_mode: ").append(!Settings.UUID.OFFLINE).append(';') | ||||||
|                         .append(!Settings.UUID.OFFLINE).append('\n'); |                         .append(!Settings.UUID.OFFLINE).append('\n'); | ||||||
|   | |||||||
| @@ -113,38 +113,34 @@ public class Help extends Command { | |||||||
|             } |             } | ||||||
|             if (cat == null && page == 0) { |             if (cat == null && page == 0) { | ||||||
|                 TextComponent.Builder builder = Component.text(); |                 TextComponent.Builder builder = Component.text(); | ||||||
|                 builder.append(MINI_MESSAGE.deserialize(TranslatableCaption.of("help.help_header").getComponent(player))); |                 builder.append(TranslatableCaption.of("help.help_header").toComponent(player)); | ||||||
|                 for (CommandCategory c : CommandCategory.values()) { |                 for (CommandCategory c : CommandCategory.values()) { | ||||||
|                     if (!c.canAccess(player)) { |                     if (!c.canAccess(player)) { | ||||||
|                         continue; |                         continue; | ||||||
|                     } |                     } | ||||||
|                     builder.append(Component.newline()).append(MINI_MESSAGE |                     builder.append(Component.newline()); | ||||||
|                             .deserialize( |                     builder.append(TranslatableCaption.of("help.help_info_item").toComponent( | ||||||
|                                     TranslatableCaption.of("help.help_info_item").getComponent(player), |                             player, TagResolver.builder() | ||||||
|                                     TagResolver.builder() |                                     .tag("command", Tag.inserting(Component.text("/plot help"))) | ||||||
|                                             .tag("command", Tag.inserting(Component.text("/plot help"))) |                                     .tag("category", Tag.inserting(Component.text(c.name().toLowerCase()))) | ||||||
|                                             .tag("category", Tag.inserting(Component.text(c.name().toLowerCase()))) |                                     .tag("category_desc", Tag.inserting(c.toComponent(player))) | ||||||
|                                             .tag("category_desc", Tag.inserting(c.toComponent(player))) |                                     .build() | ||||||
|                                             .build() |                     )); | ||||||
|                             )); |  | ||||||
|                 } |                 } | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE |                 builder.append(Component.newline()); | ||||||
|                         .deserialize( |                 builder.append(TranslatableCaption.of("help.help_info_item").toComponent( | ||||||
|                                 TranslatableCaption.of("help.help_info_item").getComponent(player), |                         player, TagResolver.builder() | ||||||
|                                 TagResolver.builder() |                                 .tag("command", Tag.inserting(Component.text("/plot help"))) | ||||||
|                                         .tag("command", Tag.inserting(Component.text("/plot help"))) |                                 .tag("category", Tag.inserting(Component.text("all"))) | ||||||
|                                         .tag("category", Tag.inserting(Component.text("all"))) |                                 .tag( | ||||||
|                                         .tag( |                                         "category_desc", Tag.inserting(TranslatableCaption | ||||||
|                                                 "category_desc", |                                                 .of("help.help_display_all_commands") | ||||||
|                                                 Tag.inserting(TranslatableCaption |                                                 .toComponent(player)) | ||||||
|                                                         .of("help.help_display_all_commands") |                                 ) | ||||||
|                                                         .toComponent(player)) |                                 .build() | ||||||
|                                         ) |                 )); | ||||||
|                                         .build() |                 builder.append(Component.newline()); | ||||||
|                         )); |                 builder.append(TranslatableCaption.of("help.help_footer").toComponent(player)); | ||||||
|                 builder.append(Component.newline()).append(MINI_MESSAGE.deserialize(TranslatableCaption |  | ||||||
|                         .of("help.help_footer") |  | ||||||
|                         .getComponent(player))); |  | ||||||
|                 player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.asComponent()))); |                 player.sendMessage(StaticCaption.of(MINI_MESSAGE.serialize(builder.asComponent()))); | ||||||
|                 return true; |                 return true; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -20,7 +20,6 @@ package com.plotsquared.core.command; | |||||||
|  |  | ||||||
| import com.plotsquared.core.configuration.Settings; | import com.plotsquared.core.configuration.Settings; | ||||||
| import com.plotsquared.core.configuration.caption.Caption; | import com.plotsquared.core.configuration.caption.Caption; | ||||||
| import com.plotsquared.core.configuration.caption.StaticCaption; |  | ||||||
| import com.plotsquared.core.configuration.caption.TranslatableCaption; | import com.plotsquared.core.configuration.caption.TranslatableCaption; | ||||||
| import com.plotsquared.core.database.DBFunc; | import com.plotsquared.core.database.DBFunc; | ||||||
| import com.plotsquared.core.permissions.Permission; | import com.plotsquared.core.permissions.Permission; | ||||||
| @@ -131,13 +130,9 @@ public class Info extends SubCommand { | |||||||
|             info = getCaption(arg); |             info = getCaption(arg); | ||||||
|             if (info == null) { |             if (info == null) { | ||||||
|                 if (Settings.Ratings.USE_LIKES) { |                 if (Settings.Ratings.USE_LIKES) { | ||||||
|                     player.sendMessage(StaticCaption.of( |                     player.sendMessage(TranslatableCaption.of("info.plot_info_categories.use_likes")); | ||||||
|                             "&6Categories&7: &amembers&7, &aalias&7, &abiome&7, &aseen&7, &adenied&7, &aflags&7, &aid&7, &asize&7, &atrusted&7, " |  | ||||||
|                                     + "&aowner&7, " + " &alikes")); |  | ||||||
|                 } else { |                 } else { | ||||||
|                     player.sendMessage(StaticCaption.of( |                     player.sendMessage(TranslatableCaption.of("info.plot_info_categories.use_rating")); | ||||||
|                             "&6Categories&7: &amembers&7, &aalias&7, &abiome&7, &aseen&7, &adenied&7, &aflags&7, &aid&7, &asize&7, &atrusted&7, " |  | ||||||
|                                     + "&aowner&7, " + " &arating")); |  | ||||||
|                 } |                 } | ||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|   | |||||||
| @@ -57,7 +57,7 @@ public class Music extends SubCommand { | |||||||
|                     "music_disc_far", "music_disc_mall", "music_disc_mellohi", "music_disc_stal", |                     "music_disc_far", "music_disc_mall", "music_disc_mellohi", "music_disc_stal", | ||||||
|                     "music_disc_strad", "music_disc_ward", "music_disc_11", "music_disc_wait", "music_disc_otherside", |                     "music_disc_strad", "music_disc_ward", "music_disc_11", "music_disc_wait", "music_disc_otherside", | ||||||
|                     "music_disc_pigstep", "music_disc_5", "music_disc_relic", "music_disc_creator", |                     "music_disc_pigstep", "music_disc_5", "music_disc_relic", "music_disc_creator", | ||||||
|                     "music_disc_creator_music_box", "music_disc_precipice" |                     "music_disc_creator_music_box", "music_disc_precipice", "music_disc_tears", "music_disc_lava_chicken" | ||||||
|             ); |             ); | ||||||
|  |  | ||||||
|     // make sure all discs and the bedrock ("cancel") fit into the inventory |     // make sure all discs and the bedrock ("cancel") fit into the inventory | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ package com.plotsquared.core.configuration.caption; | |||||||
|  |  | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.ComponentLike; | import net.kyori.adventure.text.ComponentLike; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -44,6 +45,16 @@ public interface Caption { | |||||||
|      */ |      */ | ||||||
|     @NonNull Component toComponent(@NonNull LocaleHolder localeHolder); |     @NonNull Component toComponent(@NonNull LocaleHolder localeHolder); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Get the Adventure {@link ComponentLike} for this caption while applying custom {@link TagResolver} | ||||||
|  |      * (apart from the default {@code core.prefix}) | ||||||
|  |      * @param localeHolder Local holder | ||||||
|  |      * @param tagResolvers custom tag resolvers to replace placeholders / parameters | ||||||
|  |      * @return {@link ComponentLike} | ||||||
|  |      * @since 7.5.4 | ||||||
|  |      */ | ||||||
|  |     @NonNull Component toComponent(@NonNull LocaleHolder localeHolder, @NonNull TagResolver @NonNull... tagResolvers); | ||||||
|  |  | ||||||
|     @NonNull String toString(); |     @NonNull String toString(); | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -21,6 +21,7 @@ package com.plotsquared.core.configuration.caption; | |||||||
| import com.google.common.base.Preconditions; | import com.google.common.base.Preconditions; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; | import net.kyori.adventure.text.minimessage.MiniMessage; | ||||||
|  | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
|  |  | ||||||
| public final class StaticCaption implements Caption { | public final class StaticCaption implements Caption { | ||||||
| @@ -51,6 +52,14 @@ public final class StaticCaption implements Caption { | |||||||
|         return MiniMessage.miniMessage().deserialize(this.value); |         return MiniMessage.miniMessage().deserialize(this.value); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public @NonNull Component toComponent( | ||||||
|  |             @NonNull final LocaleHolder localeHolder, | ||||||
|  |             final @NonNull TagResolver @NonNull ... tagResolvers | ||||||
|  |     ) { | ||||||
|  |         return MiniMessage.miniMessage().deserialize(this.value, tagResolvers); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull String toString() { |     public @NonNull String toString() { | ||||||
|         return "StaticCaption(" + value + ")"; |         return "StaticCaption(" + value + ")"; | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | |||||||
| import org.checkerframework.checker.nullness.qual.NonNull; | import org.checkerframework.checker.nullness.qual.NonNull; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.jetbrains.annotations.NotNull; | ||||||
|  |  | ||||||
|  | import java.util.Arrays; | ||||||
| import java.util.Locale; | import java.util.Locale; | ||||||
| import java.util.regex.Pattern; | import java.util.regex.Pattern; | ||||||
|  |  | ||||||
| @@ -96,13 +97,23 @@ public final class TranslatableCaption implements NamespacedCaption { | |||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|     public @NonNull Component toComponent(@NonNull final LocaleHolder localeHolder) { |     public @NonNull Component toComponent(@NonNull final LocaleHolder localeHolder) { | ||||||
|  |         return this.toComponent(localeHolder, new TagResolver[0]); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     @Override | ||||||
|  |     public @NonNull Component toComponent( | ||||||
|  |             @NonNull final LocaleHolder localeHolder, | ||||||
|  |             final @NonNull TagResolver @NonNull ... tagResolvers | ||||||
|  |     ) { | ||||||
|         if (getKey().equals("core.prefix")) { |         if (getKey().equals("core.prefix")) { | ||||||
|             return MiniMessage.miniMessage().deserialize(getComponent(localeHolder)); |             return MiniMessage.miniMessage().deserialize(getComponent(localeHolder)); | ||||||
|         } |         } | ||||||
|         return MiniMessage.miniMessage().deserialize(getComponent(localeHolder), TagResolver.resolver( |         TagResolver[] finalResolvers = Arrays.copyOf(tagResolvers, tagResolvers.length + 1); | ||||||
|  |         finalResolvers[finalResolvers.length - 1] = TagResolver.resolver( | ||||||
|                 "prefix", |                 "prefix", | ||||||
|                 Tag.inserting(TranslatableCaption.of("core.prefix").toComponent(localeHolder)) |                 Tag.inserting(TranslatableCaption.of("core.prefix").toComponent(localeHolder)) | ||||||
|         )); |         ); | ||||||
|  |         return MiniMessage.miniMessage().deserialize(getComponent(localeHolder), finalResolvers); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     @Override |     @Override | ||||||
|   | |||||||
| @@ -63,4 +63,18 @@ public class PlotTitle { | |||||||
|         return subtitle; |         return subtitle; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * Provides a string representation of this plot title value (used in placeholders). | ||||||
|  |      * | ||||||
|  |      * @return the plot title representation in the format {@code "<title>" "<subtitle>"} | ||||||
|  |      * @since TODO | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public String toString() { | ||||||
|  |         return "\"%s\" \"%s\"".formatted( | ||||||
|  |                 this.title != null ? this.title : "", | ||||||
|  |                 this.subtitle != null ? this.subtitle : "" | ||||||
|  |         ); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -25,30 +25,24 @@ import com.plotsquared.core.player.PlotPlayer; | |||||||
| import com.plotsquared.core.util.StringMan; | import com.plotsquared.core.util.StringMan; | ||||||
| import net.kyori.adventure.text.Component; | import net.kyori.adventure.text.Component; | ||||||
| import net.kyori.adventure.text.ComponentLike; | import net.kyori.adventure.text.ComponentLike; | ||||||
| import net.kyori.adventure.text.minimessage.MiniMessage; |  | ||||||
| import net.kyori.adventure.text.minimessage.tag.Tag; | import net.kyori.adventure.text.minimessage.tag.Tag; | ||||||
| import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | import net.kyori.adventure.text.minimessage.tag.resolver.TagResolver; | ||||||
| import org.jetbrains.annotations.NotNull; | import org.jetbrains.annotations.NotNull; | ||||||
|  |  | ||||||
| public class HelpObject implements ComponentLike { | public class HelpObject implements ComponentLike { | ||||||
|  |  | ||||||
|     static final MiniMessage MINI_MESSAGE = MiniMessage.miniMessage(); |  | ||||||
|  |  | ||||||
|     private final Component rendered; |     private final Component rendered; | ||||||
|  |  | ||||||
|     public HelpObject(final Command command, final String label, final PlotPlayer<?> audience) { |     public HelpObject(final Command command, final String label, final PlotPlayer<?> audience) { | ||||||
|         rendered = MINI_MESSAGE.deserialize( |         this.rendered = TranslatableCaption.of("help.help_item").toComponent(audience, TagResolver.builder() | ||||||
|                 TranslatableCaption.of("help.help_item").getComponent(audience), |                 .tag("usage", Tag.inserting(Component.text(command.getUsage().replace("{label}", label)))) | ||||||
|                 TagResolver.builder() |                 .tag("alias", Tag.inserting(Component.text( | ||||||
|                         .tag("usage", Tag.inserting(Component.text(command.getUsage().replace("{label}", label)))) |                         command.getAliases().isEmpty() ? "" : StringMan.join(command.getAliases(), " | ") | ||||||
|                         .tag("alias", Tag.inserting(Component.text( |                 ))) | ||||||
|                                 command.getAliases().isEmpty() ? "" : StringMan.join(command.getAliases(), " | ") |                 .tag("desc", Tag.inserting(command.getDescription().toComponent(audience))) | ||||||
|                         ))) |                 .tag("arguments", Tag.inserting(Component.text(buildArgumentList(command.getRequiredArguments())))) | ||||||
|                         .tag("desc", Tag.inserting(command.getDescription().toComponent(audience))) |                 .tag("label", Tag.inserting(Component.text(label))) | ||||||
|                         .tag("arguments", Tag.inserting(Component.text(buildArgumentList(command.getRequiredArguments())))) |                 .build()); | ||||||
|                         .tag("label", Tag.inserting(Component.text(label))) |  | ||||||
|                         .build() |  | ||||||
|         ); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private String buildArgumentList(final Argument<?>[] arguments) { |     private String buildArgumentList(final Argument<?>[] arguments) { | ||||||
|   | |||||||
| @@ -353,6 +353,8 @@ | |||||||
|   "info.infinite": "<gray>Infinite</gray>", |   "info.infinite": "<gray>Infinite</gray>", | ||||||
|   "info.plot_unowned": "<prefix><red>The current plot must have an owner to perform this action.</red>", |   "info.plot_unowned": "<prefix><red>The current plot must have an owner to perform this action.</red>", | ||||||
|   "info.plot_info_unclaimed": "<prefix><gray>Plot <gold><plot></gold> is not yet claimed.</gray>", |   "info.plot_info_unclaimed": "<prefix><gray>Plot <gold><plot></gold> is not yet claimed.</gray>", | ||||||
|  |   "info.plot_info_categories.use_rating": "<prefix><gold>Categories: </gold> <gray>members, alias, biome, seen, denied, flags, id, size, trusted, owner, rating</gray>", | ||||||
|  |   "info.plot_info_categories.use_likes": "<prefix><gold>Categories: </gold> <gray>members, alias, biome, seen, denied, flags, id, size, trusted, owner, likes</gray>", | ||||||
|   "info.plot_info_header": "<dark_gray><strikethrough>--------- <reset><gold>INFO </gold><dark_gray><strikethrough>---------</dark_gray><reset>", |   "info.plot_info_header": "<dark_gray><strikethrough>--------- <reset><gold>INFO </gold><dark_gray><strikethrough>---------</dark_gray><reset>", | ||||||
|   "info.plot_info_hidden": "<prefix><red>You cannot view the information about this plot.</red>", |   "info.plot_info_hidden": "<prefix><red>You cannot view the information about this plot.</red>", | ||||||
|   "info.plot_info_format": "<header>\n<gold>ID: <gray><id></gray>\nCreation: <gray><creationdate></gray>\nArea: <gray><area></gray>\nAlias: <gray><alias></gray>\nOwner: <gray><owner></gray>\nBiome: <gray><biome></gray>\nCan Build: <gray><build></gray>\nRating: <gray><rating></gray>\nSeen: <gray><seen></gray>\nTrusted: <gray><trusted></gray>\nMembers: <gray><members></gray>\nDenied: <gray><denied></gray>\nFlags: <gray><flags></gray>\nDescription: <gray><desc></gray></gold>\n<footer>", |   "info.plot_info_format": "<header>\n<gold>ID: <gray><id></gray>\nCreation: <gray><creationdate></gray>\nArea: <gray><area></gray>\nAlias: <gray><alias></gray>\nOwner: <gray><owner></gray>\nBiome: <gray><biome></gray>\nCan Build: <gray><build></gray>\nRating: <gray><rating></gray>\nSeen: <gray><seen></gray>\nTrusted: <gray><trusted></gray>\nMembers: <gray><members></gray>\nDenied: <gray><denied></gray>\nFlags: <gray><flags></gray>\nDescription: <gray><desc></gray></gold>\n<footer>", | ||||||
|   | |||||||
| @@ -22,7 +22,7 @@ plugins { | |||||||
| } | } | ||||||
|  |  | ||||||
| group = "com.intellectualsites.plotsquared" | group = "com.intellectualsites.plotsquared" | ||||||
| version = "7.5.3-SNAPSHOT" | version = "7.5.5-SNAPSHOT" | ||||||
|  |  | ||||||
| if (!File("$rootDir/.git").exists()) { | if (!File("$rootDir/.git").exists()) { | ||||||
|     logger.lifecycle(""" |     logger.lifecycle(""" | ||||||
| @@ -69,8 +69,8 @@ subprojects { | |||||||
|  |  | ||||||
|     dependencies { |     dependencies { | ||||||
|         // Tests |         // Tests | ||||||
|         testImplementation("org.junit.jupiter:junit-jupiter:5.12.2") |         testImplementation("org.junit.jupiter:junit-jupiter:5.13.3") | ||||||
|         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.12.2") |         testRuntimeOnly("org.junit.platform:junit-platform-launcher:1.13.3") | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     plugins.withId("java") { |     plugins.withId("java") { | ||||||
| @@ -206,14 +206,14 @@ tasks.getByName<Jar>("jar") { | |||||||
|     enabled = false |     enabled = false | ||||||
| } | } | ||||||
|  |  | ||||||
| val supportedVersions = listOf("1.19.4", "1.20.6", "1.21.1", "1.21.3", "1.21.4") | val supportedVersions = listOf("1.19.4", "1.20.6", "1.21.1", "1.21.3", "1.21.4", "1.21.5") | ||||||
| tasks { | tasks { | ||||||
|     register("cacheLatestFaweArtifact") { |     register("cacheLatestFaweArtifact") { | ||||||
|         val lastSuccessfulBuildUrl = uri("https://ci.athion.net/job/FastAsyncWorldEdit/lastSuccessfulBuild/api/json").toURL() |         val lastSuccessfulBuildUrl = uri("https://ci.athion.net/job/FastAsyncWorldEdit/lastSuccessfulBuild/api/json").toURL() | ||||||
|         val artifact = ((JsonSlurper().parse(lastSuccessfulBuildUrl) as Map<*, *>)["artifacts"] as List<*>) |         val artifact = ((JsonSlurper().parse(lastSuccessfulBuildUrl) as Map<*, *>)["artifacts"] as List<*>) | ||||||
|                 .map { it as Map<*, *> } |                 .map { it as Map<*, *> } | ||||||
|                 .map { it["fileName"] as String } |                 .map { it["fileName"] as String } | ||||||
|                 .first { it -> it.contains("Bukkit") } |                 .first { it -> it.contains("Paper") } | ||||||
|         project.ext["faweArtifact"] = artifact |         project.ext["faweArtifact"] = artifact | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,40 +3,40 @@ | |||||||
| paper = "1.20.4-R0.1-SNAPSHOT" | paper = "1.20.4-R0.1-SNAPSHOT" | ||||||
| guice = "7.0.0" | guice = "7.0.0" | ||||||
| spotbugs = "4.9.3" | spotbugs = "4.9.3" | ||||||
| checkerqual = "3.49.2" | checkerqual = "3.49.5" | ||||||
| gson = "2.10" | gson = "2.10" | ||||||
| guava = "31.1-jre" | guava = "31.1-jre" | ||||||
| snakeyaml = "2.0" | snakeyaml = "2.0" | ||||||
| adventure = "4.20.0" | adventure = "4.21.0" | ||||||
| adventure-bukkit = "4.3.4" | adventure-bukkit = "4.4.0" | ||||||
| log4j = "2.19.0" | log4j = "2.19.0" | ||||||
|  |  | ||||||
| # Plugins | # Plugins | ||||||
| worldedit = "7.2.20" | worldedit = "7.2.20" | ||||||
| fawe = "2.13.0" | fawe = "2.13.0" | ||||||
| placeholderapi = "2.11.6" | placeholderapi = "2.11.6" | ||||||
| luckperms = "5.4" | luckperms = "5.5" | ||||||
| essentialsx = "2.21.0" | essentialsx = "2.21.1" | ||||||
| mvdwapi = "3.1.1" | mvdwapi = "3.1.1" | ||||||
|  |  | ||||||
| # Third party | # Third party | ||||||
| prtree = "2.0.1" | prtree = "2.0.1" | ||||||
| aopalliance = "1.0" | aopalliance = "1.0" | ||||||
| cloud-services = "1.8.4" | cloud-services = "1.8.4" | ||||||
| arkitektonika = "2.1.3" | arkitektonika = "2.1.4" | ||||||
| squirrelid = "0.3.2" | squirrelid = "0.3.2" | ||||||
| paster = "1.1.6" | paster = "1.1.7" | ||||||
| bstats = "3.1.0" | bstats = "3.1.0" | ||||||
| paperlib = "1.0.8" | paperlib = "1.0.8" | ||||||
| informative-annotations = "1.5" | informative-annotations = "1.6" | ||||||
| vault = "1.7.1" | vault = "1.7.1" | ||||||
| serverlib = "2.3.7" | serverlib = "2.3.7" | ||||||
|  |  | ||||||
| # Gradle plugins | # Gradle plugins | ||||||
| shadow = "8.3.6" | shadow = "8.3.8" | ||||||
| grgit = "4.1.1" | grgit = "4.1.1" | ||||||
| spotless = "7.0.3" | spotless = "7.1.0" | ||||||
| publish = "0.31.0" | publish = "0.33.0" | ||||||
| runPaper = "2.3.1" | runPaper = "2.3.1" | ||||||
|  |  | ||||||
| [libraries] | [libraries] | ||||||
|   | |||||||
							
								
								
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								gradle/wrapper/gradle-wrapper.jar
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								gradle/wrapper/gradle-wrapper.properties
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| distributionBase=GRADLE_USER_HOME | distributionBase=GRADLE_USER_HOME | ||||||
| distributionPath=wrapper/dists | distributionPath=wrapper/dists | ||||||
| distributionUrl=https\://services.gradle.org/distributions/gradle-8.13-bin.zip | distributionUrl=https\://services.gradle.org/distributions/gradle-8.14.3-bin.zip | ||||||
| networkTimeout=10000 | networkTimeout=10000 | ||||||
| validateDistributionUrl=true | validateDistributionUrl=true | ||||||
| zipStoreBase=GRADLE_USER_HOME | zipStoreBase=GRADLE_USER_HOME | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								gradlew
									
									
									
									
										vendored
									
									
								
							| @@ -114,7 +114,7 @@ case "$( uname )" in                #( | |||||||
|   NONSTOP* )        nonstop=true ;; |   NONSTOP* )        nonstop=true ;; | ||||||
| esac | esac | ||||||
|  |  | ||||||
| CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | CLASSPATH="\\\"\\\"" | ||||||
|  |  | ||||||
|  |  | ||||||
| # Determine the Java command to use to start the JVM. | # Determine the Java command to use to start the JVM. | ||||||
| @@ -213,7 +213,7 @@ DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | |||||||
| set -- \ | set -- \ | ||||||
|         "-Dorg.gradle.appname=$APP_BASE_NAME" \ |         "-Dorg.gradle.appname=$APP_BASE_NAME" \ | ||||||
|         -classpath "$CLASSPATH" \ |         -classpath "$CLASSPATH" \ | ||||||
|         org.gradle.wrapper.GradleWrapperMain \ |         -jar "$APP_HOME/gradle/wrapper/gradle-wrapper.jar" \ | ||||||
|         "$@" |         "$@" | ||||||
|  |  | ||||||
| # Stop when "xargs" is not available. | # Stop when "xargs" is not available. | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								gradlew.bat
									
									
									
									
										vendored
									
									
								
							| @@ -70,11 +70,11 @@ goto fail | |||||||
| :execute | :execute | ||||||
| @rem Setup the command line | @rem Setup the command line | ||||||
|  |  | ||||||
| set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | set CLASSPATH= | ||||||
|  |  | ||||||
|  |  | ||||||
| @rem Execute Gradle | @rem Execute Gradle | ||||||
| "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | "%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" -jar "%APP_HOME%\gradle\wrapper\gradle-wrapper.jar" %* | ||||||
|  |  | ||||||
| :end | :end | ||||||
| @rem End local scope for the variables with windows NT shell | @rem End local scope for the variables with windows NT shell | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user