mirror of
				https://github.com/IntellectualSites/PlotSquared.git
				synced 2025-11-04 03:03:43 +01:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			fix/compon
			...
			feature/mi
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					cf117ff13b | 
@@ -41,6 +41,7 @@ dependencies {
 | 
				
			|||||||
    compileOnly(libs.luckperms)
 | 
					    compileOnly(libs.luckperms)
 | 
				
			||||||
    compileOnly(libs.essentialsx)
 | 
					    compileOnly(libs.essentialsx)
 | 
				
			||||||
    compileOnly(libs.mvdwapi) { isTransitive = false }
 | 
					    compileOnly(libs.mvdwapi) { isTransitive = false }
 | 
				
			||||||
 | 
					    compileOnly(libs.miniplaceholders) { isTransitive = false }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // Other libraries
 | 
					    // Other libraries
 | 
				
			||||||
    implementation(libs.squirrelid) { isTransitive = false }
 | 
					    implementation(libs.squirrelid) { isTransitive = false }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -252,8 +252,7 @@ public class PlayerEventListener implements Listener {
 | 
				
			|||||||
                }
 | 
					                }
 | 
				
			||||||
                Plot plot = location.getOwnedPlot();
 | 
					                Plot plot = location.getOwnedPlot();
 | 
				
			||||||
                if (plot == null) {
 | 
					                if (plot == null) {
 | 
				
			||||||
                    if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, EditSignFlag.class, false)
 | 
					                    if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, EditSignFlag.class, false)) {
 | 
				
			||||||
                            && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString())) {
 | 
					 | 
				
			||||||
                        event.setCancelled(true);
 | 
					                        event.setCancelled(true);
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    return;
 | 
					                    return;
 | 
				
			||||||
@@ -261,8 +260,7 @@ public class PlayerEventListener implements Listener {
 | 
				
			|||||||
                if (plot.isAdded(event.getPlayer().getUniqueId())) {
 | 
					                if (plot.isAdded(event.getPlayer().getUniqueId())) {
 | 
				
			||||||
                    return; // allow for added players
 | 
					                    return; // allow for added players
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (!plot.getFlag(EditSignFlag.class)
 | 
					                if (!plot.getFlag(EditSignFlag.class)) {
 | 
				
			||||||
                        && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString())) {
 | 
					 | 
				
			||||||
                    plot.debug(event.getPlayer().getName() + " could not color the sign because of edit-sign = false");
 | 
					                    plot.debug(event.getPlayer().getName() + " could not color the sign because of edit-sign = false");
 | 
				
			||||||
                    event.setCancelled(true);
 | 
					                    event.setCancelled(true);
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -20,7 +20,6 @@ package com.plotsquared.bukkit.listener;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import com.plotsquared.bukkit.util.BukkitUtil;
 | 
					import com.plotsquared.bukkit.util.BukkitUtil;
 | 
				
			||||||
import com.plotsquared.core.location.Location;
 | 
					import com.plotsquared.core.location.Location;
 | 
				
			||||||
import com.plotsquared.core.permissions.Permission;
 | 
					 | 
				
			||||||
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.flag.implementations.EditSignFlag;
 | 
					import com.plotsquared.core.plot.flag.implementations.EditSignFlag;
 | 
				
			||||||
@@ -47,8 +46,7 @@ public class PlayerEventListener1201 implements Listener {
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
        Plot plot = location.getOwnedPlot();
 | 
					        Plot plot = location.getOwnedPlot();
 | 
				
			||||||
        if (plot == null) {
 | 
					        if (plot == null) {
 | 
				
			||||||
            if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, EditSignFlag.class, false)
 | 
					            if (PlotFlagUtil.isAreaRoadFlagsAndFlagEquals(area, EditSignFlag.class, false)) {
 | 
				
			||||||
                    && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString())) {
 | 
					 | 
				
			||||||
                event.setCancelled(true);
 | 
					                event.setCancelled(true);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
@@ -56,8 +54,7 @@ public class PlayerEventListener1201 implements Listener {
 | 
				
			|||||||
        if (plot.isAdded(event.getPlayer().getUniqueId())) {
 | 
					        if (plot.isAdded(event.getPlayer().getUniqueId())) {
 | 
				
			||||||
            return; // allow for added players
 | 
					            return; // allow for added players
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        if (!plot.getFlag(EditSignFlag.class)
 | 
					        if (!plot.getFlag(EditSignFlag.class)) {
 | 
				
			||||||
                && !event.getPlayer().hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString())) {
 | 
					 | 
				
			||||||
            plot.debug(event.getPlayer().getName() + " could not edit the sign because of edit-sign = false");
 | 
					            plot.debug(event.getPlayer().getName() + " could not edit the sign because of edit-sign = false");
 | 
				
			||||||
            event.setCancelled(true);
 | 
					            event.setCancelled(true);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -21,6 +21,7 @@ package com.plotsquared.bukkit.listener;
 | 
				
			|||||||
import com.google.inject.Inject;
 | 
					import com.google.inject.Inject;
 | 
				
			||||||
import com.plotsquared.bukkit.BukkitPlatform;
 | 
					import com.plotsquared.bukkit.BukkitPlatform;
 | 
				
			||||||
import com.plotsquared.bukkit.placeholder.MVdWPlaceholders;
 | 
					import com.plotsquared.bukkit.placeholder.MVdWPlaceholders;
 | 
				
			||||||
 | 
					import com.plotsquared.bukkit.placeholder.MiniPlaceholders;
 | 
				
			||||||
import com.plotsquared.bukkit.util.BukkitEconHandler;
 | 
					import com.plotsquared.bukkit.util.BukkitEconHandler;
 | 
				
			||||||
import com.plotsquared.core.PlotSquared;
 | 
					import com.plotsquared.core.PlotSquared;
 | 
				
			||||||
import com.plotsquared.core.configuration.Settings;
 | 
					import com.plotsquared.core.configuration.Settings;
 | 
				
			||||||
@@ -52,6 +53,11 @@ public class ServerListener implements Listener {
 | 
				
			|||||||
            new MVdWPlaceholders(this.plugin, this.plugin.placeholderRegistry());
 | 
					            new MVdWPlaceholders(this.plugin, this.plugin.placeholderRegistry());
 | 
				
			||||||
            ConsolePlayer.getConsole().sendMessage(TranslatableCaption.of("placeholder.hooked"));
 | 
					            ConsolePlayer.getConsole().sendMessage(TranslatableCaption.of("placeholder.hooked"));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					        if (Bukkit.getPluginManager().getPlugin("MiniPlaceholders") != null
 | 
				
			||||||
 | 
					                && Settings.Enabled_Components.USE_MINIPLACEHOLDERS) {
 | 
				
			||||||
 | 
					            new MiniPlaceholders(this.plugin.placeholderRegistry());
 | 
				
			||||||
 | 
					            ConsolePlayer.getConsole().sendMessage(TranslatableCaption.of("placeholder.miniplaceholders.hooked"));
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
        if (Settings.Enabled_Components.ECONOMY && Bukkit.getPluginManager().isPluginEnabled("Vault")) {
 | 
					        if (Settings.Enabled_Components.ECONOMY && Bukkit.getPluginManager().isPluginEnabled("Vault")) {
 | 
				
			||||||
            EconHandler econHandler = new BukkitEconHandler();
 | 
					            EconHandler econHandler = new BukkitEconHandler();
 | 
				
			||||||
            try {
 | 
					            try {
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,69 @@
 | 
				
			|||||||
 | 
					/*
 | 
				
			||||||
 | 
					 * PlotSquared, a land and world management plugin for Minecraft.
 | 
				
			||||||
 | 
					 * Copyright (C) IntellectualSites <https://intellectualsites.com>
 | 
				
			||||||
 | 
					 * Copyright (C) IntellectualSites team and contributors
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This program is free software: you can redistribute it and/or modify
 | 
				
			||||||
 | 
					 * it under the terms of the GNU General Public License as published by
 | 
				
			||||||
 | 
					 * the Free Software Foundation, either version 3 of the License, or
 | 
				
			||||||
 | 
					 * (at your option) any later version.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * This program is distributed in the hope that it will be useful,
 | 
				
			||||||
 | 
					 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
				
			||||||
 | 
					 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
				
			||||||
 | 
					 * GNU General Public License for more details.
 | 
				
			||||||
 | 
					 *
 | 
				
			||||||
 | 
					 * You should have received a copy of the GNU General Public License
 | 
				
			||||||
 | 
					 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					package com.plotsquared.bukkit.placeholder;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import com.google.common.eventbus.Subscribe;
 | 
				
			||||||
 | 
					import com.plotsquared.bukkit.util.BukkitUtil;
 | 
				
			||||||
 | 
					import com.plotsquared.core.PlotSquared;
 | 
				
			||||||
 | 
					import com.plotsquared.core.player.ConsolePlayer;
 | 
				
			||||||
 | 
					import com.plotsquared.core.player.PlotPlayer;
 | 
				
			||||||
 | 
					import com.plotsquared.core.util.placeholders.Placeholder;
 | 
				
			||||||
 | 
					import com.plotsquared.core.util.placeholders.PlaceholderRegistry;
 | 
				
			||||||
 | 
					import io.github.miniplaceholders.api.Expansion;
 | 
				
			||||||
 | 
					import io.github.miniplaceholders.api.utils.TagsUtils;
 | 
				
			||||||
 | 
					import org.bukkit.entity.Player;
 | 
				
			||||||
 | 
					import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public final class MiniPlaceholders {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private Expansion expansion = null;
 | 
				
			||||||
 | 
					    private final PlaceholderRegistry registry;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public MiniPlaceholders(final @NonNull PlaceholderRegistry registry) {
 | 
				
			||||||
 | 
					        this.registry = registry;
 | 
				
			||||||
 | 
					        this.createExpansion();
 | 
				
			||||||
 | 
					        PlotSquared.get().getEventDispatcher().registerListener(this);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    @Subscribe
 | 
				
			||||||
 | 
					    public void onNewPlaceholder(final PlaceholderRegistry.@NonNull PlaceholderAddedEvent event) {
 | 
				
			||||||
 | 
					        // We cannot register placeholders on the fly, so we have to replace the expansion.
 | 
				
			||||||
 | 
					        this.createExpansion();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    private synchronized void createExpansion() {
 | 
				
			||||||
 | 
					        if (this.expansion != null && this.expansion.registered()) {
 | 
				
			||||||
 | 
					            this.expansion.unregister();
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        final Expansion.Builder builder = Expansion.builder("plotsquared");
 | 
				
			||||||
 | 
					        for (final Placeholder placeholder : this.registry.getPlaceholders()) {
 | 
				
			||||||
 | 
					            builder.audiencePlaceholder(placeholder.getKey(), (audience, argumentQueue, context) -> {
 | 
				
			||||||
 | 
					                final PlotPlayer<?> plotPlayer;
 | 
				
			||||||
 | 
					                if (audience instanceof Player player) {
 | 
				
			||||||
 | 
					                    plotPlayer = BukkitUtil.adapt(player);
 | 
				
			||||||
 | 
					                } else {
 | 
				
			||||||
 | 
					                    plotPlayer = ConsolePlayer.getConsole();
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                return TagsUtils.staticTag(placeholder.getValue(plotPlayer));
 | 
				
			||||||
 | 
					            });
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        this.expansion = builder.build();
 | 
				
			||||||
 | 
					        this.expansion.register();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -55,14 +55,6 @@ public class TranslationUpdateManager {
 | 
				
			|||||||
        String userMove = "userMove";
 | 
					        String userMove = "userMove";
 | 
				
			||||||
        String userMoveReplacement = "user_move";
 | 
					        String userMoveReplacement = "user_move";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        // tag opening / closing characters are important, as the locale keys exist as well, which should not be replaced
 | 
					 | 
				
			||||||
        String listInfoUnknown = "<info.unknown>";
 | 
					 | 
				
			||||||
        String listInfoUnknownReplacement = "<unknown>";
 | 
					 | 
				
			||||||
        String listInfoServer = "<info.server>";
 | 
					 | 
				
			||||||
        String listInfoServerReplacement = "<server>";
 | 
					 | 
				
			||||||
        String listInfoEveryone = "<info.everyone>";
 | 
					 | 
				
			||||||
        String listInfoEveryoneReplacement = "<everyone>";
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) {
 | 
					        try (Stream<Path> paths = Files.walk(Paths.get(PlotSquared.platform().getDirectory().toPath().resolve("lang").toUri()))) {
 | 
				
			||||||
            paths
 | 
					            paths
 | 
				
			||||||
                    .filter(Files::isRegularFile)
 | 
					                    .filter(Files::isRegularFile)
 | 
				
			||||||
@@ -76,9 +68,6 @@ public class TranslationUpdateManager {
 | 
				
			|||||||
                        replaceInFile(p, minimumRadius, minimumRadiusReplacement);
 | 
					                        replaceInFile(p, minimumRadius, minimumRadiusReplacement);
 | 
				
			||||||
                        replaceInFile(p, maximumMoves, maximumMovesReplacement);
 | 
					                        replaceInFile(p, maximumMoves, maximumMovesReplacement);
 | 
				
			||||||
                        replaceInFile(p, userMove, userMoveReplacement);
 | 
					                        replaceInFile(p, userMove, userMoveReplacement);
 | 
				
			||||||
                        replaceInFile(p, listInfoUnknown, listInfoUnknownReplacement);
 | 
					 | 
				
			||||||
                        replaceInFile(p, listInfoServer, listInfoServerReplacement);
 | 
					 | 
				
			||||||
                        replaceInFile(p, listInfoEveryone, listInfoEveryoneReplacement);
 | 
					 | 
				
			||||||
                    });
 | 
					                    });
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -37,9 +37,7 @@ import com.sk89q.worldedit.regions.CuboidRegion;
 | 
				
			|||||||
import com.sk89q.worldedit.world.biome.BiomeType;
 | 
					import com.sk89q.worldedit.world.biome.BiomeType;
 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.NonNull;
 | 
					import org.checkerframework.checker.nullness.qual.NonNull;
 | 
				
			||||||
import org.checkerframework.checker.nullness.qual.Nullable;
 | 
					import org.checkerframework.checker.nullness.qual.Nullable;
 | 
				
			||||||
import org.jetbrains.annotations.NotNull;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
import java.util.Objects;
 | 
					 | 
				
			||||||
import java.util.Set;
 | 
					import java.util.Set;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
public class FaweRegionManager extends BukkitRegionManager {
 | 
					public class FaweRegionManager extends BukkitRegionManager {
 | 
				
			||||||
@@ -61,10 +59,7 @@ public class FaweRegionManager extends BukkitRegionManager {
 | 
				
			|||||||
            @Nullable PlotPlayer<?> actor,
 | 
					            @Nullable PlotPlayer<?> actor,
 | 
				
			||||||
            @Nullable QueueCoordinator queue
 | 
					            @Nullable QueueCoordinator queue
 | 
				
			||||||
    ) {
 | 
					    ) {
 | 
				
			||||||
        return delegate.setCuboids(
 | 
					        return delegate.setCuboids(area, regions, blocks, minY, maxY, queue.getCompleteTask());
 | 
				
			||||||
                area, regions, blocks, minY, maxY,
 | 
					 | 
				
			||||||
                Objects.requireNonNullElseGet(queue, area::getQueue).getCompleteTask()
 | 
					 | 
				
			||||||
        );
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
@@ -116,7 +111,7 @@ public class FaweRegionManager extends BukkitRegionManager {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @Override
 | 
					    @Override
 | 
				
			||||||
    public boolean regenerateRegion(final @NotNull Location pos1, final @NotNull Location pos2, boolean ignore, final Runnable whenDone) {
 | 
					    public boolean regenerateRegion(final Location pos1, final Location pos2, boolean ignore, final Runnable whenDone) {
 | 
				
			||||||
        return delegate.regenerateRegion(pos1, pos2, ignore, whenDone);
 | 
					        return delegate.regenerateRegion(pos1, pos2, ignore, whenDone);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -465,7 +465,7 @@ public class ListCmd extends SubCommand {
 | 
				
			|||||||
                TextComponent.Builder builder = Component.text();
 | 
					                TextComponent.Builder builder = Component.text();
 | 
				
			||||||
                if (plot.getFlag(ServerPlotFlag.class)) {
 | 
					                if (plot.getFlag(ServerPlotFlag.class)) {
 | 
				
			||||||
                    TagResolver serverResolver = TagResolver.resolver(
 | 
					                    TagResolver serverResolver = TagResolver.resolver(
 | 
				
			||||||
                            "server",
 | 
					                            "info.server",
 | 
				
			||||||
                            Tag.inserting(TranslatableCaption.of("info.server").toComponent(player))
 | 
					                            Tag.inserting(TranslatableCaption.of("info.server").toComponent(player))
 | 
				
			||||||
                    );
 | 
					                    );
 | 
				
			||||||
                    builder.append(MINI_MESSAGE.deserialize(server, serverResolver));
 | 
					                    builder.append(MINI_MESSAGE.deserialize(server, serverResolver));
 | 
				
			||||||
@@ -483,13 +483,13 @@ public class ListCmd extends SubCommand {
 | 
				
			|||||||
                                builder.append(MINI_MESSAGE.deserialize(online, resolver));
 | 
					                                builder.append(MINI_MESSAGE.deserialize(online, resolver));
 | 
				
			||||||
                            } else if (uuidMapping.username().equalsIgnoreCase("unknown")) {
 | 
					                            } else if (uuidMapping.username().equalsIgnoreCase("unknown")) {
 | 
				
			||||||
                                TagResolver unknownResolver = TagResolver.resolver(
 | 
					                                TagResolver unknownResolver = TagResolver.resolver(
 | 
				
			||||||
                                        "unknown",
 | 
					                                        "info.unknown",
 | 
				
			||||||
                                        Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player))
 | 
					                                        Tag.inserting(TranslatableCaption.of("info.unknown").toComponent(player))
 | 
				
			||||||
                                );
 | 
					                                );
 | 
				
			||||||
                                builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver));
 | 
					                                builder.append(MINI_MESSAGE.deserialize(unknown, unknownResolver));
 | 
				
			||||||
                            } else if (uuidMapping.uuid().equals(DBFunc.EVERYONE)) {
 | 
					                            } else if (uuidMapping.uuid().equals(DBFunc.EVERYONE)) {
 | 
				
			||||||
                                TagResolver everyoneResolver = TagResolver.resolver(
 | 
					                                TagResolver everyoneResolver = TagResolver.resolver(
 | 
				
			||||||
                                        "everyone",
 | 
					                                        "info.everyone",
 | 
				
			||||||
                                        Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player))
 | 
					                                        Tag.inserting(TranslatableCaption.of("info.everyone").toComponent(player))
 | 
				
			||||||
                                );
 | 
					                                );
 | 
				
			||||||
                                builder.append(MINI_MESSAGE.deserialize(everyone, everyoneResolver));
 | 
					                                builder.append(MINI_MESSAGE.deserialize(everyone, everyoneResolver));
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -810,6 +810,10 @@ public class Settings extends Config {
 | 
				
			|||||||
        );
 | 
					        );
 | 
				
			||||||
        @Comment("Whether PlotSquared should hook into MvDWPlaceholderAPI or not")
 | 
					        @Comment("Whether PlotSquared should hook into MvDWPlaceholderAPI or not")
 | 
				
			||||||
        public static boolean USE_MVDWAPI = true;
 | 
					        public static boolean USE_MVDWAPI = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        @Comment("Whether PlotSquared should hook into MiniPlaceholders")
 | 
				
			||||||
 | 
					        public static boolean USE_MINIPLACEHOLDERS = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        @Comment("Prevent cross plot beacon effects")
 | 
					        @Comment("Prevent cross plot beacon effects")
 | 
				
			||||||
        public static boolean DISABLE_BEACON_EFFECT_OVERFLOW = true;
 | 
					        public static boolean DISABLE_BEACON_EFFECT_OVERFLOW = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -2401,8 +2401,7 @@ public class SQLManager implements AbstractDB {
 | 
				
			|||||||
        addPlotTask(plot, new UniqueStatement("setPosition") {
 | 
					        addPlotTask(plot, new UniqueStatement("setPosition") {
 | 
				
			||||||
            @Override
 | 
					            @Override
 | 
				
			||||||
            public void set(PreparedStatement statement) throws SQLException {
 | 
					            public void set(PreparedStatement statement) throws SQLException {
 | 
				
			||||||
                // Please see the table creation statement. There is the default value of "default"
 | 
					                statement.setString(1, position == null ? "" : position);
 | 
				
			||||||
                statement.setString(1, position == null ? "DEFAULT" : position);
 | 
					 | 
				
			||||||
                statement.setInt(2, getId(plot));
 | 
					                statement.setInt(2, getId(plot));
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -59,9 +59,6 @@ public enum Permission implements ComponentLike {
 | 
				
			|||||||
    PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED("plots.admin.vehicle.break.unowned"),
 | 
					    PERMISSION_ADMIN_DESTROY_VEHICLE_UNOWNED("plots.admin.vehicle.break.unowned"),
 | 
				
			||||||
    PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER("plots.admin.vehicle.break.other"),
 | 
					    PERMISSION_ADMIN_DESTROY_VEHICLE_OTHER("plots.admin.vehicle.break.other"),
 | 
				
			||||||
    PERMISSION_ADMIN_PVE("plots.admin.pve"),
 | 
					    PERMISSION_ADMIN_PVE("plots.admin.pve"),
 | 
				
			||||||
    PERMISSION_ADMIN_PLACE_VEHICLE_ROAD("plots.admin.vehicle.place.road"),
 | 
					 | 
				
			||||||
    PERMISSION_ADMIN_PLACE_VEHICLE_UNOWNED("plots.admin.vehicle.place.unowned"),
 | 
					 | 
				
			||||||
    PERMISSION_ADMIN_PLACE_VEHICLE_OTHER("plots.admin.vehicle.place.other"),
 | 
					 | 
				
			||||||
    PERMISSION_ADMIN_PVP("plots.admin.pvp"),
 | 
					    PERMISSION_ADMIN_PVP("plots.admin.pvp"),
 | 
				
			||||||
    PERMISSION_ADMIN_BUILD_ROAD("plots.admin.build.road"),
 | 
					    PERMISSION_ADMIN_BUILD_ROAD("plots.admin.build.road"),
 | 
				
			||||||
    PERMISSION_ADMIN_PROJECTILE_ROAD("plots.admin.projectile.road"),
 | 
					    PERMISSION_ADMIN_PROJECTILE_ROAD("plots.admin.projectile.road"),
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1483,7 +1483,7 @@ public class Plot {
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    public void setHome(BlockLoc location) {
 | 
					    public void setHome(BlockLoc location) {
 | 
				
			||||||
        Plot plot = this.getBasePlot(false);
 | 
					        Plot plot = this.getBasePlot(false);
 | 
				
			||||||
        if (location != null && (BlockLoc.ZERO.equals(location) || BlockLoc.MINY.equals(location))) {
 | 
					        if (BlockLoc.ZERO.equals(location) || BlockLoc.MINY.equals(location)) {
 | 
				
			||||||
            return;
 | 
					            return;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        plot.getSettings().setPosition(location);
 | 
					        plot.getSettings().setPosition(location);
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -382,10 +382,14 @@ public class EventDispatcher {
 | 
				
			|||||||
                            return true;
 | 
					                            return true;
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (!plot.hasOwner()) {
 | 
					                if (!plot.hasOwner()) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_UNOWNED.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                final List<BlockTypeWrapper> use = plot.getFlag(UseFlag.class);
 | 
					                final List<BlockTypeWrapper> use = plot.getFlag(UseFlag.class);
 | 
				
			||||||
                for (final BlockTypeWrapper blockTypeWrapper : use) {
 | 
					                for (final BlockTypeWrapper blockTypeWrapper : use) {
 | 
				
			||||||
@@ -394,7 +398,7 @@ public class EventDispatcher {
 | 
				
			|||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER, false)) {
 | 
					                if (player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString(), false)) {
 | 
				
			||||||
                    return true;
 | 
					                    return true;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                // we check for the EditSignFlag in the PlayerSignOpenEvent again, but we must not cancel the interact event
 | 
					                // we check for the EditSignFlag in the PlayerSignOpenEvent again, but we must not cancel the interact event
 | 
				
			||||||
@@ -419,10 +423,14 @@ public class EventDispatcher {
 | 
				
			|||||||
                            return true;
 | 
					                            return true;
 | 
				
			||||||
                        }
 | 
					                        }
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD, false);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), false
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (!plot.hasOwner()) {
 | 
					                if (!plot.hasOwner()) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED, false);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_UNOWNED.toString(), false
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (plot.getFlag(DeviceInteractFlag.class)) {
 | 
					                if (plot.getFlag(DeviceInteractFlag.class)) {
 | 
				
			||||||
                    return true;
 | 
					                    return true;
 | 
				
			||||||
@@ -434,14 +442,21 @@ public class EventDispatcher {
 | 
				
			|||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER, false);
 | 
					                return player.hasPermission(
 | 
				
			||||||
 | 
					                        Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString(),
 | 
				
			||||||
 | 
					                        false
 | 
				
			||||||
 | 
					                );
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            case SPAWN_MOB -> {
 | 
					            case SPAWN_MOB -> {
 | 
				
			||||||
                if (plot == null) {
 | 
					                if (plot == null) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (!plot.hasOwner()) {
 | 
					                if (!plot.hasOwner()) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_UNOWNED.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (plot.getFlag(MobPlaceFlag.class)) {
 | 
					                if (plot.getFlag(MobPlaceFlag.class)) {
 | 
				
			||||||
                    return true;
 | 
					                    return true;
 | 
				
			||||||
@@ -453,7 +468,10 @@ public class EventDispatcher {
 | 
				
			|||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER, false)) {
 | 
					                if (player.hasPermission(
 | 
				
			||||||
 | 
					                        Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString(),
 | 
				
			||||||
 | 
					                        false
 | 
				
			||||||
 | 
					                )) {
 | 
				
			||||||
                    return true;
 | 
					                    return true;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (notifyPerms) {
 | 
					                if (notifyPerms) {
 | 
				
			||||||
@@ -473,10 +491,14 @@ public class EventDispatcher {
 | 
				
			|||||||
            }
 | 
					            }
 | 
				
			||||||
            case PLACE_MISC -> {
 | 
					            case PLACE_MISC -> {
 | 
				
			||||||
                if (plot == null) {
 | 
					                if (plot == null) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_ROAD, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (!plot.hasOwner()) {
 | 
					                if (!plot.hasOwner()) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_UNOWNED, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_UNOWNED.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (plot.getFlag(MiscPlaceFlag.class)) {
 | 
					                if (plot.getFlag(MiscPlaceFlag.class)) {
 | 
				
			||||||
                    return true;
 | 
					                    return true;
 | 
				
			||||||
@@ -488,7 +510,10 @@ public class EventDispatcher {
 | 
				
			|||||||
                        return true;
 | 
					                        return true;
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (player.hasPermission(Permission.PERMISSION_ADMIN_INTERACT_OTHER, false)) {
 | 
					                if (player.hasPermission(
 | 
				
			||||||
 | 
					                        Permission.PERMISSION_ADMIN_INTERACT_OTHER.toString(),
 | 
				
			||||||
 | 
					                        false
 | 
				
			||||||
 | 
					                )) {
 | 
				
			||||||
                    return true;
 | 
					                    return true;
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (notifyPerms) {
 | 
					                if (notifyPerms) {
 | 
				
			||||||
@@ -508,28 +533,16 @@ public class EventDispatcher {
 | 
				
			|||||||
            }
 | 
					            }
 | 
				
			||||||
            case PLACE_VEHICLE -> {
 | 
					            case PLACE_VEHICLE -> {
 | 
				
			||||||
                if (plot == null) {
 | 
					                if (plot == null) {
 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_PLACE_VEHICLE_ROAD, notifyPerms);
 | 
					                    return player.hasPermission(
 | 
				
			||||||
                }
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_ROAD.toString(), notifyPerms
 | 
				
			||||||
                if (!plot.hasOwner()) {
 | 
					 | 
				
			||||||
                    return player.hasPermission(Permission.PERMISSION_ADMIN_PLACE_VEHICLE_UNOWNED, notifyPerms);
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                if (plot.getFlag(VehiclePlaceFlag.class)) {
 | 
					 | 
				
			||||||
                    return true;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                if (player.hasPermission(Permission.PERMISSION_ADMIN_PLACE_VEHICLE_OTHER, false)) {
 | 
					 | 
				
			||||||
                    return true;
 | 
					 | 
				
			||||||
                }
 | 
					 | 
				
			||||||
                if (notifyPerms) {
 | 
					 | 
				
			||||||
                    player.sendMessage(
 | 
					 | 
				
			||||||
                            TranslatableCaption.of("commandconfig.flag_tutorial_usage"),
 | 
					 | 
				
			||||||
                            TagResolver.resolver(
 | 
					 | 
				
			||||||
                                    "flag",
 | 
					 | 
				
			||||||
                                    Tag.inserting(
 | 
					 | 
				
			||||||
                                            PlotFlag.getFlagNameComponent(VehiclePlaceFlag.class)
 | 
					 | 
				
			||||||
                                    )
 | 
					 | 
				
			||||||
                            )
 | 
					 | 
				
			||||||
                    );
 | 
					                    );
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					                if (!plot.hasOwner()) {
 | 
				
			||||||
 | 
					                    return player.hasPermission(
 | 
				
			||||||
 | 
					                            Permission.PERMISSION_ADMIN_INTERACT_UNOWNED.toString(), notifyPerms
 | 
				
			||||||
 | 
					                    );
 | 
				
			||||||
 | 
					                }
 | 
				
			||||||
 | 
					                return plot.getFlag(VehiclePlaceFlag.class);
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
            default -> {
 | 
					            default -> {
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -190,6 +190,7 @@
 | 
				
			|||||||
  "core.prefix": "<dark_gray>[</dark_gray><gold>P2</gold><dark_gray>] </dark_gray>",
 | 
					  "core.prefix": "<dark_gray>[</dark_gray><gold>P2</gold><dark_gray>] </dark_gray>",
 | 
				
			||||||
  "core.enabled": "<prefix><gold><value> is now enabled.</gold>",
 | 
					  "core.enabled": "<prefix><gold><value> is now enabled.</gold>",
 | 
				
			||||||
  "placeholder.hooked": "<prefix><gold>PlotSquared hooked into MVdWPlaceholderAPI</gold>",
 | 
					  "placeholder.hooked": "<prefix><gold>PlotSquared hooked into MVdWPlaceholderAPI</gold>",
 | 
				
			||||||
 | 
					  "placeholder.miniplaceholders.hooked": "<prefix><gold>PlotSquared hooked into MiniPlaceholders</gold>",
 | 
				
			||||||
  "placeholder.nan": "Not a number",
 | 
					  "placeholder.nan": "Not a number",
 | 
				
			||||||
  "reload.reloaded_configs": "<prefix><gold>Translations and world settings have been reloaded successfully.</gold>",
 | 
					  "reload.reloaded_configs": "<prefix><gold>Translations and world settings have been reloaded successfully.</gold>",
 | 
				
			||||||
  "reload.reload_failed": "<prefix><red>Failed to reload file configurations.</red>",
 | 
					  "reload.reload_failed": "<prefix><red>Failed to reload file configurations.</red>",
 | 
				
			||||||
@@ -381,9 +382,9 @@
 | 
				
			|||||||
  "info.plot_list_default": "<gold><plot></gold>",
 | 
					  "info.plot_list_default": "<gold><plot></gold>",
 | 
				
			||||||
  "info.plot_list_player_online": "<dark_aqua><prefix></dark_aqua><hover:show_text:'<dark_aqua>Online</dark_aqua>'><gold><player></gold></hover>",
 | 
					  "info.plot_list_player_online": "<dark_aqua><prefix></dark_aqua><hover:show_text:'<dark_aqua>Online</dark_aqua>'><gold><player></gold></hover>",
 | 
				
			||||||
  "info.plot_list_player_offline": "<dark_aqua><prefix></dark_aqua><hover:show_text:'<dark_gray>Offline</dark_gray>'><gold><player></gold></hover>",
 | 
					  "info.plot_list_player_offline": "<dark_aqua><prefix></dark_aqua><hover:show_text:'<dark_gray>Offline</dark_gray>'><gold><player></gold></hover>",
 | 
				
			||||||
  "info.plot_list_player_unknown": "<hover:show_text:'<red>The owner of this plot is unknown</red>'><white><unknown></white></hover>",
 | 
					  "info.plot_list_player_unknown": "<hover:show_text:'<red>The owner of this plot is unknown</red>'><white><info.unknown></white></hover>",
 | 
				
			||||||
  "info.plot_list_player_server": "<hover:show_text:'<red>The plot is owned by the server</red>'><white><server></white></hover>",
 | 
					  "info.plot_list_player_server": "<hover:show_text:'<red>The plot is owned by the server</red>'><white><info.server></white></hover>",
 | 
				
			||||||
  "info.plot_list_player_everyone": "<hover:show_text:'<blue>The plot is owned by everyone</blue>'><white><everyone></white></hover>",
 | 
					  "info.plot_list_player_everyone": "<hover:show_text:'<blue>The plot is owned by everyone</blue>'><white><info.everyone></white></hover>",
 | 
				
			||||||
  "info.area_info_format": "<header>\n<reset><gold>Name: </gold><gray><name></gray>\n<gold>Type: </gold><gray><type></gray>\n<gold>Terrain: </gold><gray><terrain></gray>\n<gold>Usage: </gold><gray><usage>%</gray>\n<gold>Claimed: </gold><gray><claimed></gray>\n<gold>Clusters: </gold><gray><clusters></gray>\n<gold>Region: </gold><gray><region></gray>\n<gold>Generator: </gold><gray><generator></gray>\n<footer>",
 | 
					  "info.area_info_format": "<header>\n<reset><gold>Name: </gold><gray><name></gray>\n<gold>Type: </gold><gray><type></gray>\n<gold>Terrain: </gold><gray><terrain></gray>\n<gold>Usage: </gold><gray><usage>%</gray>\n<gold>Claimed: </gold><gray><claimed></gray>\n<gold>Clusters: </gold><gray><clusters></gray>\n<gold>Region: </gold><gray><region></gray>\n<gold>Generator: </gold><gray><generator></gray>\n<footer>",
 | 
				
			||||||
  "info.area_list_tooltip": "<gold>Claimed=</gold><gray><claimed></gray>\n<gold>Usage=</gold><gray><usage></gray>\n<gold>Clusters=</gold><gray><clusters></gray>\n<gold>Region=</gold><gray><region></gray>\n<gold>Generator=</gold><gray><generator></gray>",
 | 
					  "info.area_list_tooltip": "<gold>Claimed=</gold><gray><claimed></gray>\n<gold>Usage=</gold><gray><usage></gray>\n<gold>Clusters=</gold><gray><clusters></gray>\n<gold>Region=</gold><gray><region></gray>\n<gold>Generator=</gold><gray><generator></gray>",
 | 
				
			||||||
  "info.area_list_item": "<click:run_command:'<command_tp>'><hover:show_text:'<command_tp>'><dark_gray>[</dark_gray><gold><number></gold><dark_gray>]</dark_gray></hover></click> <click:run_command:'<command_info>'><hover:show_text:'<hover_info>'><gold><area_name></gold></hover></click><gray> - </gray><gray><area_type>:<area_terrain></gray>",
 | 
					  "info.area_list_item": "<click:run_command:'<command_tp>'><hover:show_text:'<command_tp>'><dark_gray>[</dark_gray><gold><number></gold><dark_gray>]</dark_gray></hover></click> <click:run_command:'<command_info>'><hover:show_text:'<hover_info>'><gold><area_name></gold></hover></click><gray> - </gray><gray><area_type>:<area_terrain></gray>",
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -13,11 +13,12 @@ log4j = "2.19.0"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# Plugins
 | 
					# Plugins
 | 
				
			||||||
worldedit = "7.2.18"
 | 
					worldedit = "7.2.18"
 | 
				
			||||||
fawe = "2.8.4"
 | 
					fawe = "2.8.3"
 | 
				
			||||||
placeholderapi = "2.11.5"
 | 
					placeholderapi = "2.11.5"
 | 
				
			||||||
luckperms = "5.4"
 | 
					luckperms = "5.4"
 | 
				
			||||||
essentialsx = "2.20.1"
 | 
					essentialsx = "2.20.1"
 | 
				
			||||||
mvdwapi = "3.1.1"
 | 
					mvdwapi = "3.1.1"
 | 
				
			||||||
 | 
					miniplaceholders = "2.2.3"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Third party
 | 
					# Third party
 | 
				
			||||||
prtree = "2.0.1"
 | 
					prtree = "2.0.1"
 | 
				
			||||||
@@ -68,6 +69,7 @@ prtree = { group = "com.intellectualsites.prtree", name = "PRTree", version.ref
 | 
				
			|||||||
aopalliance = { group = "aopalliance", name = "aopalliance", version.ref = "aopalliance" }
 | 
					aopalliance = { group = "aopalliance", name = "aopalliance", version.ref = "aopalliance" }
 | 
				
			||||||
cloudServices = { group = "cloud.commandframework", name = "cloud-services", version.ref = "cloud-services" }
 | 
					cloudServices = { group = "cloud.commandframework", name = "cloud-services", version.ref = "cloud-services" }
 | 
				
			||||||
mvdwapi = { group = "com.intellectualsites.mvdwplaceholderapi", name = "MVdWPlaceholderAPI", version.ref = "mvdwapi" }
 | 
					mvdwapi = { group = "com.intellectualsites.mvdwplaceholderapi", name = "MVdWPlaceholderAPI", version.ref = "mvdwapi" }
 | 
				
			||||||
 | 
					miniplaceholders = { group = "io.github.miniplaceholders", name = "miniplaceholders-api", version.ref = "miniplaceholders" }
 | 
				
			||||||
squirrelid = { group = "org.enginehub", name = "squirrelid", version.ref = "squirrelid" }
 | 
					squirrelid = { group = "org.enginehub", name = "squirrelid", version.ref = "squirrelid" }
 | 
				
			||||||
arkitektonika = { group = "com.intellectualsites.arkitektonika", name = "Arkitektonika-Client", version.ref = "arkitektonika" }
 | 
					arkitektonika = { group = "com.intellectualsites.arkitektonika", name = "Arkitektonika-Client", version.ref = "arkitektonika" }
 | 
				
			||||||
paster = { group = "com.intellectualsites.paster", name = "Paster", version.ref = "paster" }
 | 
					paster = { group = "com.intellectualsites.paster", name = "Paster", version.ref = "paster" }
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user