mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-23 00:21:43 +01:00
Fixed player page kills formatting
This commit is contained in:
parent
5021ada67f
commit
78654d6552
@ -113,4 +113,8 @@ public class PlayerKill implements DateHolder {
|
||||
"date=" + date + ", " +
|
||||
"weapon='" + weapon + "'}";
|
||||
}
|
||||
|
||||
public boolean isSelfKill() {
|
||||
return getVictimName().map(v -> v.equals(killerName)).orElse(false);
|
||||
}
|
||||
}
|
||||
|
@ -37,6 +37,10 @@ public class PlayerKillMutator {
|
||||
this.kills = kills;
|
||||
}
|
||||
|
||||
public PlayerKillMutator filterNonSelfKills() {
|
||||
return new PlayerKillMutator(kills.stream().filter(PlayerKill::isSelfKill).collect(Collectors.toList()));
|
||||
}
|
||||
|
||||
public List<Map<String, Object>> toJSONAsMap(Formatters formatters) {
|
||||
return kills.stream().map(
|
||||
kill -> {
|
||||
|
@ -17,6 +17,7 @@
|
||||
package com.djrapitops.plan.system.json;
|
||||
|
||||
import com.djrapitops.plan.data.container.GeoInfo;
|
||||
import com.djrapitops.plan.data.container.PlayerKill;
|
||||
import com.djrapitops.plan.data.store.containers.PlayerContainer;
|
||||
import com.djrapitops.plan.data.store.keys.PlayerKeys;
|
||||
import com.djrapitops.plan.data.store.mutators.*;
|
||||
@ -89,6 +90,8 @@ public class PlayerJSONParser {
|
||||
SessionsMutator sessionsMutator = SessionsMutator.forContainer(player);
|
||||
Map<UUID, WorldTimes> worldTimesPerServer = PerServerMutator.forContainer(player).worldTimesPerServer();
|
||||
List<Map<String, Object>> serverAccordion = new ServerAccordion(player, serverNames, graphs, year, timeAmount).asMaps();
|
||||
List<PlayerKill> kills = player.getValue(PlayerKeys.PLAYER_KILLS).orElse(Collections.emptyList());
|
||||
List<PlayerKill> deaths = player.getValue(PlayerKeys.PLAYER_DEATHS_KILLS).orElse(Collections.emptyList());
|
||||
|
||||
Map<String, Object> data = new HashMap<>();
|
||||
data.put("info", createInfoJSONMap(player, serverNames));
|
||||
@ -101,8 +104,8 @@ public class PlayerJSONParser {
|
||||
data.put("connections", player.getValue(PlayerKeys.GEO_INFO)
|
||||
.map(geoInfo -> ConnectionInfo.fromGeoInfo(geoInfo, year))
|
||||
.orElse(Collections.emptyList()));
|
||||
data.put("player_kills", player.getValue(PlayerKeys.PLAYER_KILLS).orElse(Collections.emptyList()));
|
||||
data.put("player_deaths", player.getValue(PlayerKeys.PLAYER_DEATHS_KILLS).orElse(Collections.emptyList()));
|
||||
data.put("player_kills", new PlayerKillMutator(kills).filterNonSelfKills().toJSONAsMap(formatters));
|
||||
data.put("player_deaths", new PlayerKillMutator(deaths).toJSONAsMap(formatters));
|
||||
data.put("sessions", sessionsMutator.toServerNameJSONMaps(graphs, config.getWorldAliasSettings(), formatters));
|
||||
data.put("sessions_per_page", config.get(DisplaySettings.SESSIONS_PER_PAGE));
|
||||
data.put("servers", serverAccordion);
|
||||
|
@ -104,7 +104,9 @@ function createKillsTable(player_kills) {
|
||||
for (var i = 0; i < player_kills.length; i++) {
|
||||
var kill = player_kills[i];
|
||||
table += '<tr><td>' + kill.date + '</td>' +
|
||||
'<td>' + kill.killer + '<i class="fa fa-fw fa-angle-right col-red"></i>' + kill.victim + '</td>' +
|
||||
'<td>' + kill.killer +
|
||||
(kill.killer === kill.victim ? '<i class="fa fa-fw fa-skull-crossbones col-red"></i>' : '<i class="fa fa-fw fa-angle-right col-red"></i>') +
|
||||
kill.victim + '</td>' +
|
||||
'<td>' + kill.weapon + '</td></tr>'
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user