[Fix] Locale lang group replacement changes

Changed the Lang that was being used to replace things on the html, now
some of the Lang is no longer used. (CmdHelpLang, CommandLang, etc)
GenericLang caused page breakage due to wrong replacements, so it is no
longer used for replacement

Affected issues: Fixes #706
This commit is contained in:
Rsl1122 2018-09-23 17:39:15 +03:00
parent ef9bf00ddf
commit cbb45bf49d

View File

@ -1,14 +1,16 @@
package com.djrapitops.plan.system.locale; package com.djrapitops.plan.system.locale;
import com.djrapitops.plan.PlanPlugin; import com.djrapitops.plan.PlanPlugin;
import com.djrapitops.plan.system.locale.lang.Lang; import com.djrapitops.plan.system.locale.lang.*;
import com.djrapitops.plan.system.settings.Settings; import com.djrapitops.plan.system.settings.Settings;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.Serializable; import java.io.Serializable;
import java.util.Arrays;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.function.Function;
import java.util.stream.Collectors; import java.util.stream.Collectors;
/** /**
@ -71,10 +73,22 @@ public class Locale extends HashMap<Lang, Message> {
String replaced = from; String replaced = from;
// Longest first so that entries that contain each other don't partially replace. Lang[][] langs = new Lang[][]{
List<Entry<Lang, Message>> entries = entrySet().stream().sorted( NetworkPageLang.values(),
(one, two) -> Integer.compare(two.getKey().getIdentifier().length(), one.getKey().getIdentifier().length()) PlayerPageLang.values(),
).collect(Collectors.toList()); ServerPageLang.values(),
CommonHtmlLang.values()
};
List<Entry<Lang, Message>> entries = Arrays.stream(langs)
.flatMap(Arrays::stream)
.collect(Collectors.toMap(Function.identity(), this::get))
.entrySet().stream()
// Longest first so that entries that contain each other don't partially replace.
.sorted((one, two) -> Integer.compare(
two.getKey().getIdentifier().length(),
one.getKey().getIdentifier().length()
)).collect(Collectors.toList());
for (Entry<Lang, Message> entry : entries) { for (Entry<Lang, Message> entry : entries) {
String defaultValue = entry.getKey().getDefault(); String defaultValue = entry.getKey().getDefault();