mirror of
https://github.com/BentoBoxWorld/Challenges.git
synced 2025-01-16 21:21:28 +01:00
Fix confusing Select Challenge GUI. #86
Left Click on challenge will immediately return to previous panel (status = true), right click will select challenge.
This commit is contained in:
parent
14660dd42c
commit
8f9aa78435
@ -611,12 +611,25 @@ public class ChallengesManager
|
|||||||
* @param user - user
|
* @param user - user
|
||||||
* @param challenge - challenge
|
* @param challenge - challenge
|
||||||
*/
|
*/
|
||||||
public void setChallengeComplete(User user, Challenge challenge)
|
public void setChallengeComplete(@NonNull User user, @NonNull Challenge challenge)
|
||||||
|
{
|
||||||
|
this.setChallengeComplete(user.getUniqueId(), challenge);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the challenge as complete and increments the number of times it has been
|
||||||
|
* completed
|
||||||
|
*
|
||||||
|
* @param user - user
|
||||||
|
* @param challenge - challenge
|
||||||
|
*/
|
||||||
|
public void setChallengeComplete(@NonNull UUID user, @NonNull Challenge challenge)
|
||||||
{
|
{
|
||||||
this.addPlayer(user);
|
this.addPlayer(user);
|
||||||
this.playerCacheData.get(user.getUniqueId()).setChallengeDone(challenge.getUniqueId());
|
this.playerCacheData.get(user).setChallengeDone(challenge.getUniqueId());
|
||||||
// Save
|
// Save
|
||||||
this.savePlayer(user.getUniqueId());
|
this.savePlayer(user);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -627,11 +640,23 @@ public class ChallengesManager
|
|||||||
* @param challenge - challenge
|
* @param challenge - challenge
|
||||||
*/
|
*/
|
||||||
public void resetChallenge(@NonNull User user, @NonNull Challenge challenge)
|
public void resetChallenge(@NonNull User user, @NonNull Challenge challenge)
|
||||||
|
{
|
||||||
|
this.resetChallenge(user.getUniqueId(), challenge);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reset the challenge to zero time / not done
|
||||||
|
*
|
||||||
|
* @param user - user
|
||||||
|
* @param challenge - challenge
|
||||||
|
*/
|
||||||
|
public void resetChallenge(@NonNull UUID user, @NonNull Challenge challenge)
|
||||||
{
|
{
|
||||||
this.addPlayer(user);
|
this.addPlayer(user);
|
||||||
this.playerCacheData.get(user.getUniqueId()).setChallengeTimes(challenge.getUniqueId(), 0);
|
this.playerCacheData.get(user).setChallengeTimes(challenge.getUniqueId(), 0);
|
||||||
// Save
|
// Save
|
||||||
this.savePlayer(user.getUniqueId());
|
this.savePlayer(user);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -596,10 +596,10 @@ public class EditLevelGUI extends CommonGUI
|
|||||||
() -> new LinkedHashMap<>(challengeList.size())));
|
() -> new LinkedHashMap<>(challengeList.size())));
|
||||||
|
|
||||||
// Open select gui
|
// Open select gui
|
||||||
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, value) -> {
|
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, valueSet) -> {
|
||||||
if (status)
|
if (status)
|
||||||
{
|
{
|
||||||
manager.addChallengeToLevel(value, this.challengeLevel);
|
valueSet.forEach(challenge -> manager.addChallengeToLevel(challenge, this.challengeLevel));
|
||||||
}
|
}
|
||||||
|
|
||||||
this.build();
|
this.build();
|
||||||
@ -629,10 +629,10 @@ public class EditLevelGUI extends CommonGUI
|
|||||||
() -> new LinkedHashMap<>(challengeList.size())));
|
() -> new LinkedHashMap<>(challengeList.size())));
|
||||||
|
|
||||||
// Open select gui
|
// Open select gui
|
||||||
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, value) -> {
|
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, valueSet) -> {
|
||||||
if (status)
|
if (status)
|
||||||
{
|
{
|
||||||
manager.removeChallengeFromLevel(value, this.challengeLevel);
|
valueSet.forEach(challenge -> manager.removeChallengeFromLevel(challenge, this.challengeLevel));
|
||||||
}
|
}
|
||||||
|
|
||||||
this.build();
|
this.build();
|
||||||
|
@ -196,15 +196,13 @@ public class ListUsersGUI extends CommonGUI
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, value) -> {
|
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, valueSet) -> {
|
||||||
if (status)
|
if (status)
|
||||||
{
|
{
|
||||||
manager.setChallengeComplete(User.getInstance(player), value);
|
valueSet.forEach(challenge -> manager.setChallengeComplete(player.getUniqueId(), challenge));
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this.build();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.build();
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
case RESET:
|
case RESET:
|
||||||
@ -218,15 +216,13 @@ public class ListUsersGUI extends CommonGUI
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, value) -> {
|
new SelectChallengeGUI(this.user, challengeDescriptionMap, lineLength, (status, valueSet) -> {
|
||||||
if (status)
|
if (status)
|
||||||
{
|
{
|
||||||
manager.resetChallenge(User.getInstance(player), value);
|
valueSet.forEach(challenge -> manager.resetChallenge(player.getUniqueId(), challenge));
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this.build();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.build();
|
||||||
});
|
});
|
||||||
break;
|
break;
|
||||||
case RESET_ALL:
|
case RESET_ALL:
|
||||||
|
@ -2,9 +2,8 @@ package world.bentobox.challenges.panel.util;
|
|||||||
|
|
||||||
|
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
import java.util.ArrayList;
|
import org.bukkit.event.inventory.ClickType;
|
||||||
import java.util.List;
|
import java.util.*;
|
||||||
import java.util.Map;
|
|
||||||
import java.util.function.BiConsumer;
|
import java.util.function.BiConsumer;
|
||||||
|
|
||||||
import world.bentobox.bentobox.api.panels.PanelItem;
|
import world.bentobox.bentobox.api.panels.PanelItem;
|
||||||
@ -20,13 +19,14 @@ import world.bentobox.challenges.utils.GuiUtils;
|
|||||||
*/
|
*/
|
||||||
public class SelectChallengeGUI
|
public class SelectChallengeGUI
|
||||||
{
|
{
|
||||||
public SelectChallengeGUI(User user, Map<Challenge, List<String>> challengesDescriptionMap, int lineLength, BiConsumer<Boolean, Challenge> consumer)
|
public SelectChallengeGUI(User user, Map<Challenge, List<String>> challengesDescriptionMap, int lineLength, BiConsumer<Boolean, Set<Challenge>> consumer)
|
||||||
{
|
{
|
||||||
this.consumer = consumer;
|
this.consumer = consumer;
|
||||||
this.user = user;
|
this.user = user;
|
||||||
this.challengesList = new ArrayList<>(challengesDescriptionMap.keySet());
|
this.challengesList = new ArrayList<>(challengesDescriptionMap.keySet());
|
||||||
this.challengesDescriptionMap = challengesDescriptionMap;
|
this.challengesDescriptionMap = challengesDescriptionMap;
|
||||||
this.lineLength = lineLength;
|
this.lineLength = lineLength;
|
||||||
|
this.selectedChallenges = new HashSet<>(this.challengesList.size());
|
||||||
|
|
||||||
this.build(0);
|
this.build(0);
|
||||||
}
|
}
|
||||||
@ -129,14 +129,45 @@ public class SelectChallengeGUI
|
|||||||
*/
|
*/
|
||||||
private PanelItem createChallengeButton(Challenge challenge)
|
private PanelItem createChallengeButton(Challenge challenge)
|
||||||
{
|
{
|
||||||
|
List<String> description;
|
||||||
|
|
||||||
|
if (this.selectedChallenges.contains(challenge))
|
||||||
|
{
|
||||||
|
description = new ArrayList<>();
|
||||||
|
description.add(this.user.getTranslation("challenges.gui.descriptions.admin.selected"));
|
||||||
|
description.addAll(this.challengesDescriptionMap.get(challenge));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
description = this.challengesDescriptionMap.get(challenge);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return new PanelItemBuilder().
|
return new PanelItemBuilder().
|
||||||
name(challenge.getFriendlyName()).
|
name(challenge.getFriendlyName()).
|
||||||
description(GuiUtils.stringSplit(this.challengesDescriptionMap.get(challenge), this.lineLength)).
|
description(GuiUtils.stringSplit(description, this.lineLength)).
|
||||||
icon(challenge.getIcon()).
|
icon(challenge.getIcon()).
|
||||||
clickHandler((panel, user1, clickType, slot) -> {
|
clickHandler((panel, user1, clickType, slot) -> {
|
||||||
this.consumer.accept(true, challenge);
|
if (clickType == ClickType.RIGHT)
|
||||||
|
{
|
||||||
|
// If challenge is not selected, then select :)
|
||||||
|
if (!this.selectedChallenges.remove(challenge))
|
||||||
|
{
|
||||||
|
this.selectedChallenges.add(challenge);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Reset button.
|
||||||
|
panel.getInventory().setItem(slot, this.createChallengeButton(challenge).getItem());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.consumer.accept(true, this.selectedChallenges);
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}).build();
|
}).
|
||||||
|
glow(this.selectedChallenges.contains(challenge)).
|
||||||
|
build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -148,7 +179,7 @@ public class SelectChallengeGUI
|
|||||||
/**
|
/**
|
||||||
* This variable stores consumer.
|
* This variable stores consumer.
|
||||||
*/
|
*/
|
||||||
private BiConsumer<Boolean, Challenge> consumer;
|
private BiConsumer<Boolean, Set<Challenge>> consumer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* User who runs GUI.
|
* User who runs GUI.
|
||||||
@ -160,6 +191,11 @@ public class SelectChallengeGUI
|
|||||||
*/
|
*/
|
||||||
private List<Challenge> challengesList;
|
private List<Challenge> challengesList;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Selected challenges that will be returned to consumer.
|
||||||
|
*/
|
||||||
|
private Set<Challenge> selectedChallenges;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Map that contains all challenge descriptions
|
* Map that contains all challenge descriptions
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user