mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-10-25 23:53:44 +02:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			7.5.7
			...
			fix/v7/spe
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 49767b568a | 
| @@ -40,6 +40,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 java.util.UUID; | import java.util.UUID; | ||||||
|  | import java.util.function.Supplier; | ||||||
|  |  | ||||||
| @CommandDeclaration(command = "merge", | @CommandDeclaration(command = "merge", | ||||||
|         aliases = "m", |         aliases = "m", | ||||||
| @@ -116,9 +117,11 @@ public class Merge extends SubCommand { | |||||||
|         if (direction == null) { |         if (direction == null) { | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("commandconfig.command_syntax"), |                     TranslatableCaption.of("commandconfig.command_syntax"), | ||||||
|                     TagResolver.resolver("value", Tag.inserting(Component.text( |                     TagResolver.resolver( | ||||||
|  |                             "value", Tag.inserting(Component.text( | ||||||
|                                     "/plot merge <" + StringMan.join(values, " | ") + "> [removeroads]" |                                     "/plot merge <" + StringMan.join(values, " | ") + "> [removeroads]" | ||||||
|                     ))) |                             )) | ||||||
|  |                     ) | ||||||
|             ); |             ); | ||||||
|             player.sendMessage( |             player.sendMessage( | ||||||
|                     TranslatableCaption.of("help.direction"), |                     TranslatableCaption.of("help.direction"), | ||||||
| @@ -244,28 +247,32 @@ public class Merge extends SubCommand { | |||||||
|         } |         } | ||||||
|         java.util.Set<UUID> uuids = adjacent.getOwners(); |         java.util.Set<UUID> uuids = adjacent.getOwners(); | ||||||
|         boolean isOnline = false; |         boolean isOnline = false; | ||||||
|  |         if (!force) { | ||||||
|             for (final UUID owner : uuids) { |             for (final UUID owner : uuids) { | ||||||
|                 final PlotPlayer<?> accepter = PlotSquared.platform().playerManager().getPlayerIfExists(owner); |                 final PlotPlayer<?> accepter = PlotSquared.platform().playerManager().getPlayerIfExists(owner); | ||||||
|             if (!force && accepter == null) { |                 if (accepter == null) { | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 isOnline = true; |                 isOnline = true; | ||||||
|                 final Direction dir = direction; |                 final Direction dir = direction; | ||||||
|             Runnable run = () -> { |                 Supplier<Boolean> run = () -> { | ||||||
|                     accepter.sendMessage(TranslatableCaption.of("merge.merge_accepted")); |                     accepter.sendMessage(TranslatableCaption.of("merge.merge_accepted")); | ||||||
|                 plot.getPlotModificationManager().autoMerge(dir, maxSize - size, owner, player, terrain); |                     if (plot.getPlotModificationManager().autoMerge(dir, maxSize - size, owner, player, terrain)) { | ||||||
|                         PlotPlayer<?> plotPlayer = PlotSquared.platform().playerManager().getPlayerIfExists(player.getUUID()); |                         PlotPlayer<?> plotPlayer = PlotSquared.platform().playerManager().getPlayerIfExists(player.getUUID()); | ||||||
|                         if (plotPlayer == null) { |                         if (plotPlayer == null) { | ||||||
|                             accepter.sendMessage(TranslatableCaption.of("merge.merge_not_valid")); |                             accepter.sendMessage(TranslatableCaption.of("merge.merge_not_valid")); | ||||||
|                     return; |                             return false; | ||||||
|                         } |                         } | ||||||
|                         if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { |                         if (this.econHandler.isEnabled(plotArea) && !player.hasPermission(Permission.PERMISSION_ADMIN_BYPASS_ECON) && price > 0d) { | ||||||
|                     if (!force && this.econHandler.getMoney(player) < price) { |                             if (this.econHandler.getMoney(player) < price) { | ||||||
|                                 player.sendMessage( |                                 player.sendMessage( | ||||||
|                                         TranslatableCaption.of("economy.cannot_afford_merge"), |                                         TranslatableCaption.of("economy.cannot_afford_merge"), | ||||||
|                                 TagResolver.resolver("money", Tag.inserting(Component.text(this.econHandler.format(price)))) |                                         TagResolver.resolver( | ||||||
|  |                                                 "money", | ||||||
|  |                                                 Tag.inserting(Component.text(this.econHandler.format(price))) | ||||||
|  |                                         ) | ||||||
|                                 ); |                                 ); | ||||||
|                         return; |                                 return false; | ||||||
|                             } |                             } | ||||||
|                             this.econHandler.withdrawMoney(player, price); |                             this.econHandler.withdrawMoney(player, price); | ||||||
|                             player.sendMessage( |                             player.sendMessage( | ||||||
| @@ -275,9 +282,14 @@ public class Merge extends SubCommand { | |||||||
|                         } |                         } | ||||||
|                         player.sendMessage(TranslatableCaption.of("merge.success_merge")); |                         player.sendMessage(TranslatableCaption.of("merge.success_merge")); | ||||||
|                         eventDispatcher.callPostMerge(player, plot); |                         eventDispatcher.callPostMerge(player, plot); | ||||||
|  |                         return true; | ||||||
|  |                     } | ||||||
|  |                     player.sendMessage(TranslatableCaption.of("merge.no_available_automerge")); | ||||||
|  |                     return false; | ||||||
|                 }; |                 }; | ||||||
|             if (!force && hasConfirmation(player)) { |                 if (hasConfirmation(player)) { | ||||||
|                 CmdConfirm.addPending(accepter, MINI_MESSAGE.serialize(MINI_MESSAGE |                     CmdConfirm.addPending( | ||||||
|  |                             accepter, MINI_MESSAGE.serialize(MINI_MESSAGE | ||||||
|                                     .deserialize( |                                     .deserialize( | ||||||
|                                             TranslatableCaption.of("merge.merge_request_confirm").getComponent(player), |                                             TranslatableCaption.of("merge.merge_request_confirm").getComponent(player), | ||||||
|                                             TagResolver.builder() |                                             TagResolver.builder() | ||||||
| @@ -288,10 +300,13 @@ public class Merge extends SubCommand { | |||||||
|                                                     ) |                                                     ) | ||||||
|                                                     .build() |                                                     .build() | ||||||
|                                     )), |                                     )), | ||||||
|                         run |                             run::get | ||||||
|                     ); |                     ); | ||||||
|                 } else { |                 } else { | ||||||
|                 run.run(); |                     return run.get(); | ||||||
|  |                 } | ||||||
|  |                 // find first | ||||||
|  |                 break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if (force || !isOnline) { |         if (force || !isOnline) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user