Skip to content

Commit

Permalink
Added API to get a translation without color conversion
Browse files Browse the repository at this point in the history
It may be necessary to read the translation without converting colors to
Bukkit colors.
  • Loading branch information
tastybento committed Sep 25, 2021
1 parent 0a4fc83 commit af3c0a8
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 7 deletions.
19 changes: 17 additions & 2 deletions src/main/java/world/bentobox/bentobox/api/user/User.java
Original file line number Diff line number Diff line change
Expand Up @@ -355,14 +355,29 @@ public String getTranslation(World world, String reference, String... variables)
}

/**
* Gets a translation of this reference for this user. Translations may be overridden by Addons
* Gets a translation of this reference for this user with colors converted. Translations may be overridden by Addons
* by using the same reference prefixed by the addon name (from the Addon Description) in lower case.
* @param reference - reference found in a locale file
* @param variables - variables to insert into translated string. Variables go in pairs, for example
* "[name]", "tastybento"
* @return Translated string with colors converted, or the reference if nothing has been found
*/
public String getTranslation(String reference, String... variables) {
// Get addonPrefix
String addonPrefix = addon == null ? "" : addon.getDescription().getName().toLowerCase(Locale.ENGLISH) + ".";
return Util.translateColorCodes(translate(addonPrefix, reference, variables));
}

/**
* Gets a translation of this reference for this user without colors translated. Translations may be overridden by Addons
* by using the same reference prefixed by the addon name (from the Addon Description) in lower case.
* @param reference - reference found in a locale file
* @param variables - variables to insert into translated string. Variables go in pairs, for example
* "[name]", "tastybento"
* @return Translated string or the reference if nothing has been found
* @since 1.17.4
*/
public String getTranslationNoColor(String reference, String... variables) {
// Get addonPrefix
String addonPrefix = addon == null ? "" : addon.getDescription().getName().toLowerCase(Locale.ENGLISH) + ".";
return translate(addonPrefix, reference, variables);
Expand Down Expand Up @@ -407,7 +422,7 @@ private String translate(String addonPrefix, String reference, String[] variable
translation = plugin.getPlaceholdersManager().replacePlaceholders(player, translation);
}

return Util.translateColorCodes(translation);
return translation;
}
}

Expand Down
19 changes: 14 additions & 5 deletions src/test/java/world/bentobox/bentobox/api/user/UserTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,8 @@
@PrepareForTest({ BentoBox.class, Bukkit.class })
public class UserTest {

private static final String TEST_TRANSLATION = "mock translation [test]";
private static final String TEST_TRANSLATION = "mock &a translation &b [test]";
private static final String TEST_TRANSLATION_WITH_COLOR = "mock §atranslation §b[test]";
@Mock
private Player player;
@Mock
Expand Down Expand Up @@ -243,7 +244,7 @@ public void testGetUniqueId() {

@Test
public void testHasPermission() {
// default behaviours
// default behaviors
assertTrue(user.hasPermission(""));
assertTrue(user.hasPermission(null));

Expand Down Expand Up @@ -276,12 +277,20 @@ public void testIsOp() {

@Test
public void testGetTranslation() {
assertEquals("mock translation [test]", user.getTranslation("a.reference"));
assertEquals(TEST_TRANSLATION_WITH_COLOR, user.getTranslation("a.reference"));
}

/**
* Test for {@link User#getTranslationNoColor(String, String...)}
*/
@Test
public void testGetTranslationNoColor() {
assertEquals(TEST_TRANSLATION, user.getTranslationNoColor("a.reference"));
}

@Test
public void testGetTranslationWithVariable() {
assertEquals("mock translation variable", user.getTranslation("a.reference", "[test]", "variable"));
assertEquals("mock §atranslation §bvariable", user.getTranslation("a.reference", "[test]", "variable"));
}

@Test
Expand All @@ -306,7 +315,7 @@ public void testGetTranslationOrNothing() {
@Test
public void testSendMessage() {
user.sendMessage("a.reference");
verify(player).sendMessage(eq(TEST_TRANSLATION));
verify(player).sendMessage(TEST_TRANSLATION_WITH_COLOR);
}

@Test
Expand Down

0 comments on commit af3c0a8

Please sign in to comment.