just making sure to have a backup online
This commit is contained in:
parent
a8e5349e31
commit
f126440c11
@ -15,6 +15,7 @@ public class MapBoardDTO {
|
|||||||
|
|
||||||
private String steamID;
|
private String steamID;
|
||||||
private String name;
|
private String name;
|
||||||
|
private String avatar;
|
||||||
private int mapPoint;
|
private int mapPoint;
|
||||||
private int mapTimeMinutes;
|
private int mapTimeMinutes;
|
||||||
private float mapTimeSeconds;
|
private float mapTimeSeconds;
|
||||||
@ -23,9 +24,10 @@ public class MapBoardDTO {
|
|||||||
public MapBoardDTO() {
|
public MapBoardDTO() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public MapBoardDTO(MapValues mapvalue, String name) {
|
public MapBoardDTO(MapValues mapvalue, String name, String avatar) {
|
||||||
this.steamID = mapvalue.getPlayerSteamID();
|
this.steamID = mapvalue.getPlayerSteamID();
|
||||||
this.name = name;
|
this.name = name;
|
||||||
|
this.avatar = avatar;
|
||||||
this.mapPoint = mapvalue.getMapPoints();
|
this.mapPoint = mapvalue.getMapPoints();
|
||||||
this.mapTimeMinutes = (int) Math.floor(mapvalue.getTime());
|
this.mapTimeMinutes = (int) Math.floor(mapvalue.getTime());
|
||||||
this.mapTimeSeconds = (float) (mapvalue.getTime() - Math.floor(mapvalue.getTime())) * 100;
|
this.mapTimeSeconds = (float) (mapvalue.getTime() - Math.floor(mapvalue.getTime())) * 100;
|
||||||
|
@ -0,0 +1,43 @@
|
|||||||
|
/*
|
||||||
|
* To change this license header, choose License Headers in Project Properties.
|
||||||
|
* To change this template file, choose Tools | Templates
|
||||||
|
* and open the template in the editor.
|
||||||
|
*/
|
||||||
|
package DTO;
|
||||||
|
|
||||||
|
import facade.Facade;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author install1
|
||||||
|
*/
|
||||||
|
public class MapBoardDTO2 {
|
||||||
|
|
||||||
|
private String mapname;
|
||||||
|
private int mapstage;
|
||||||
|
|
||||||
|
public String getMapname() {
|
||||||
|
return mapname;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMapname(String mapname) {
|
||||||
|
this.mapname = mapname;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getMapstage() {
|
||||||
|
return mapstage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setMapstage(int mapstage) {
|
||||||
|
this.mapstage = mapstage;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MapBoardDTO2() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public MapBoardDTO2(String mapname, int mapstage) {
|
||||||
|
this.mapname = mapname;
|
||||||
|
this.mapstage = mapstage;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -7,8 +7,10 @@ package DTO;
|
|||||||
|
|
||||||
import entity.MapBoard;
|
import entity.MapBoard;
|
||||||
import entity.MapValues;
|
import entity.MapValues;
|
||||||
|
import facade.Facade;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
@ -33,24 +35,13 @@ public class PlayerMapBoardDTO {
|
|||||||
this.steamID = steamID;
|
this.steamID = steamID;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addMapValues(MapValues mapvalue, String mapName) {
|
public void addMapValues(MapValues mapvalue, String mapName, int stage) {
|
||||||
Pattern pattern = Pattern.compile("S(\\d+)");
|
|
||||||
Matcher matcher = pattern.matcher(mapName);
|
|
||||||
String map = "";
|
|
||||||
int stage = 1; //0
|
|
||||||
if (matcher.find()) {
|
|
||||||
String group = matcher.group();
|
|
||||||
map = mapName.substring(0, mapName.indexOf(group));
|
|
||||||
stage = Integer.valueOf(group.substring(1));
|
|
||||||
} else {
|
|
||||||
map = mapName;
|
|
||||||
}
|
|
||||||
this.steamID = mapvalue.getPlayerSteamID();
|
this.steamID = mapvalue.getPlayerSteamID();
|
||||||
this.mapPoint = mapvalue.getMapPoints();
|
this.mapPoint = mapvalue.getMapPoints();
|
||||||
this.mapTimeMinutes = (int) Math.floor(mapvalue.getTime());
|
this.mapTimeMinutes = (int) Math.floor(mapvalue.getTime());
|
||||||
this.mapTimeSeconds = (float) (mapvalue.getTime() - Math.floor(mapvalue.getTime())) * 100;
|
this.mapTimeSeconds = (float) (mapvalue.getTime() - Math.floor(mapvalue.getTime())) * 100;
|
||||||
this.position = mapvalue.getPosition();
|
this.position = mapvalue.getPosition();
|
||||||
this.mapname = map;
|
this.mapname = mapName;
|
||||||
this.mapstage = stage;
|
this.mapstage = stage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,7 +27,8 @@ public class DataMapperCalls {
|
|||||||
|
|
||||||
public static Map.Entry<Collection<Player>, Collection<MapBoard>> getAllValues() {
|
public static Map.Entry<Collection<Player>, Collection<MapBoard>> getAllValues() {
|
||||||
Collection<Player> allPlayers = new ArrayList();
|
Collection<Player> allPlayers = new ArrayList();
|
||||||
//add mapvalues
|
//remove limitfetch eventually
|
||||||
|
|
||||||
ConcurrentMap<String, MapBoard> allMapBoards = new MapMaker().concurrencyLevel(4).makeMap();
|
ConcurrentMap<String, MapBoard> allMapBoards = new MapMaker().concurrencyLevel(4).makeMap();
|
||||||
String sqlQuery = "SELECT * FROM `zetimer_table`";
|
String sqlQuery = "SELECT * FROM `zetimer_table`";
|
||||||
int limitfetch = 0;
|
int limitfetch = 0;
|
||||||
@ -35,7 +36,7 @@ public class DataMapperCalls {
|
|||||||
try (PreparedStatement ps = con.prepareStatement(sqlQuery)) {
|
try (PreparedStatement ps = con.prepareStatement(sqlQuery)) {
|
||||||
try (ResultSet result = ps.executeQuery()) {
|
try (ResultSet result = ps.executeQuery()) {
|
||||||
int fetchSize = result.getMetaData().getColumnCount();
|
int fetchSize = result.getMetaData().getColumnCount();
|
||||||
while (result.next() && limitfetch < 25) {
|
while (result.next() /*&& limitfetch < 25*/) {
|
||||||
int timesCounter = 0;
|
int timesCounter = 0;
|
||||||
Player player = new Player(result.getString(1), result.getString(2));
|
Player player = new Player(result.getString(1), result.getString(2));
|
||||||
int i = 3;
|
int i = 3;
|
||||||
@ -48,7 +49,7 @@ public class DataMapperCalls {
|
|||||||
if (specificDouble > 0.000) {
|
if (specificDouble > 0.000) {
|
||||||
timesCounter++;
|
timesCounter++;
|
||||||
MapValues mapValue = new MapValues();
|
MapValues mapValue = new MapValues();
|
||||||
mapValue.setPlayerSteamID(player);
|
mapValue.setPlayerSteamID(player.getSteamID());
|
||||||
mapValue.setTime((float) specificDouble);
|
mapValue.setTime((float) specificDouble);
|
||||||
allMapBoards.get(columnLabel).getMapvalues().add(mapValue);
|
allMapBoards.get(columnLabel).getMapvalues().add(mapValue);
|
||||||
}
|
}
|
||||||
|
@ -71,8 +71,8 @@ public class MapValues implements Serializable {
|
|||||||
return playerSteamID;
|
return playerSteamID;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setPlayerSteamID(Player player) {
|
public void setPlayerSteamID(String steamID) {
|
||||||
this.playerSteamID = player.getSteamID();
|
this.playerSteamID = steamID;
|
||||||
}
|
}
|
||||||
|
|
||||||
public float getTime() {
|
public float getTime() {
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
package facade;
|
package facade;
|
||||||
|
|
||||||
import DTO.MapBoardDTO;
|
import DTO.MapBoardDTO;
|
||||||
|
import DTO.MapBoardDTO2;
|
||||||
import DTO.PlayerMapBoardDTO;
|
import DTO.PlayerMapBoardDTO;
|
||||||
import DTO.PlayerDTO;
|
import DTO.PlayerDTO;
|
||||||
import DataMapper.DataMapperCalls;
|
import DataMapper.DataMapperCalls;
|
||||||
@ -13,15 +14,20 @@ import java.net.MalformedURLException;
|
|||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.time.Duration;
|
import java.time.Duration;
|
||||||
import java.time.Instant;
|
import java.time.Instant;
|
||||||
|
import java.util.AbstractMap;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.concurrent.ConcurrentMap;
|
import java.util.concurrent.ConcurrentMap;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
import java.util.regex.Matcher;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
import javax.persistence.EntityManager;
|
import javax.persistence.EntityManager;
|
||||||
import javax.persistence.Query;
|
import javax.persistence.Query;
|
||||||
import org.json.JSONArray;
|
import org.json.JSONArray;
|
||||||
@ -43,6 +49,32 @@ public class Facade {
|
|||||||
initSetup = 1;
|
initSetup = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<MapBoardDTO2> getAllMaps() {
|
||||||
|
List<String> arrnames = new ArrayList(mapBoardCache.keySet());
|
||||||
|
Collections.sort(arrnames);
|
||||||
|
List<MapBoardDTO2> arrMaps = new ArrayList();
|
||||||
|
for (String str : arrnames) {
|
||||||
|
Map.Entry<String, Integer> getMapnameAndStage = GetMapnameAndStage(str);
|
||||||
|
arrMaps.add(new MapBoardDTO2(getMapnameAndStage.getKey(), getMapnameAndStage.getValue()));
|
||||||
|
}
|
||||||
|
return arrMaps;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Entry<String, Integer> GetMapnameAndStage(String mapName) {
|
||||||
|
Pattern pattern = Pattern.compile("S(\\d+)");
|
||||||
|
Matcher matcher = pattern.matcher(mapName);
|
||||||
|
String map = "";
|
||||||
|
int stage = 1; //0
|
||||||
|
if (matcher.find()) {
|
||||||
|
String group = matcher.group();
|
||||||
|
map = mapName.substring(0, mapName.indexOf(group));
|
||||||
|
stage = Integer.valueOf(group.substring(1));
|
||||||
|
} else {
|
||||||
|
map = mapName;
|
||||||
|
}
|
||||||
|
return new AbstractMap.SimpleEntry(map, stage);
|
||||||
|
}
|
||||||
|
|
||||||
public List<MapBoardDTO> getSpecificMap(String mapname, int stage) {
|
public List<MapBoardDTO> getSpecificMap(String mapname, int stage) {
|
||||||
List<MapBoardDTO> returnlist = new ArrayList();
|
List<MapBoardDTO> returnlist = new ArrayList();
|
||||||
String mapRetrieved = mapname + "S" + stage;
|
String mapRetrieved = mapname + "S" + stage;
|
||||||
@ -53,7 +85,8 @@ public class Facade {
|
|||||||
}
|
}
|
||||||
List<MapValues> mapvalues = mapBoard.getMapvalues();
|
List<MapValues> mapvalues = mapBoard.getMapvalues();
|
||||||
for (MapValues mapvalue : mapvalues) {
|
for (MapValues mapvalue : mapvalues) {
|
||||||
returnlist.add(new MapBoardDTO(mapvalue, playerCache.get(mapvalue.getPlayerSteamID()).getName()));
|
String avatar = playerCache.get(mapvalue.getPlayerSteamID()).getAvatar();
|
||||||
|
returnlist.add(new MapBoardDTO(mapvalue, playerCache.get(mapvalue.getPlayerSteamID()).getName(), avatar));
|
||||||
}
|
}
|
||||||
return returnlist;
|
return returnlist;
|
||||||
}
|
}
|
||||||
@ -64,7 +97,8 @@ public class Facade {
|
|||||||
List<PlayerMapBoardDTO> playerMapBoardDtos = new ArrayList();
|
List<PlayerMapBoardDTO> playerMapBoardDtos = new ArrayList();
|
||||||
for (Entry<String, MapValues> entries : playerMaps.entrySet()) {
|
for (Entry<String, MapValues> entries : playerMaps.entrySet()) {
|
||||||
PlayerMapBoardDTO mapBoardDto = new PlayerMapBoardDTO(steamid);
|
PlayerMapBoardDTO mapBoardDto = new PlayerMapBoardDTO(steamid);
|
||||||
mapBoardDto.addMapValues(entries.getValue(), entries.getKey());
|
Map.Entry<String, Integer> getMapnameAndStage = GetMapnameAndStage(entries.getKey());
|
||||||
|
mapBoardDto.addMapValues(entries.getValue(), getMapnameAndStage.getKey(), getMapnameAndStage.getValue());
|
||||||
playerMapBoardDtos.add(mapBoardDto);
|
playerMapBoardDtos.add(mapBoardDto);
|
||||||
}
|
}
|
||||||
return playerMapBoardDtos;
|
return playerMapBoardDtos;
|
||||||
@ -74,30 +108,25 @@ public class Facade {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public PlayerDTO getPlayer(String steamid) {
|
public PlayerDTO getPlayer(String steamid) {
|
||||||
EntityManager em = PuSelector.getEntityManagerFactory("pu").createEntityManager();
|
return new PlayerDTO(playerCache.get(steamid));
|
||||||
try {
|
|
||||||
Query query = em.createQuery("SELECT a FROM Player AS a WHERE a.steamID LIKE :steamID")
|
|
||||||
.setParameter("steamID", steamid);
|
|
||||||
Player player = (Player) query.getSingleResult();
|
|
||||||
return new PlayerDTO(player);
|
|
||||||
} finally {
|
|
||||||
em.close();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Collection<PlayerDTO> getleaderBoard() {
|
public Collection<PlayerDTO> getleaderBoard(int iterator) {
|
||||||
EntityManager em = PuSelector.getEntityManagerFactory("pu").createEntityManager();
|
int playerAddiditionCap = 150;
|
||||||
try {
|
List<Player> players = new ArrayList(playerCache.values());
|
||||||
Query query = em.createQuery("SELECT a FROM Player AS a ORDER BY A.rank ASC ");
|
|
||||||
List<Player> players = (List<Player>) query.getResultList();
|
|
||||||
Collection<PlayerDTO> playersDTO = new ArrayList();
|
Collection<PlayerDTO> playersDTO = new ArrayList();
|
||||||
|
players.sort(Comparator.comparing(Player::getRank));
|
||||||
|
int counter = 0;
|
||||||
for (Player player : players) {
|
for (Player player : players) {
|
||||||
|
if (counter >= iterator && counter <= iterator + playerAddiditionCap) {
|
||||||
playersDTO.add(new PlayerDTO(player));
|
playersDTO.add(new PlayerDTO(player));
|
||||||
}
|
}
|
||||||
return playersDTO;
|
if (counter > iterator + playerAddiditionCap) {
|
||||||
} finally {
|
break;
|
||||||
em.close();
|
|
||||||
}
|
}
|
||||||
|
counter++;
|
||||||
|
}
|
||||||
|
return playersDTO;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addNewPlayerValuesToCache(Collection<Player> keyCollection) {
|
private void addNewPlayerValuesToCache(Collection<Player> keyCollection) {
|
||||||
@ -274,9 +303,30 @@ public class Facade {
|
|||||||
setPlayerPoints();
|
setPlayerPoints();
|
||||||
updatePlayerRanks();
|
updatePlayerRanks();
|
||||||
setTimesAsociatedToPeople();
|
setTimesAsociatedToPeople();
|
||||||
|
updateEntitiesPersistence();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void updateEntitiesPersistence() {
|
||||||
|
EntityManager em = PuSelector.getEntityManagerFactory("pu").createEntityManager();
|
||||||
|
em.getTransaction().begin();
|
||||||
|
em.createQuery("delete from MapBoard").executeUpdate();
|
||||||
|
em.createQuery("delete from MapValues").executeUpdate();
|
||||||
|
em.createQuery("delete from Player").executeUpdate();
|
||||||
|
em.createQuery("delete from UrlBanners").executeUpdate();
|
||||||
|
Collection<Player> players = playerCache.values();
|
||||||
|
Collection<MapBoard> mapBoards = mapBoardCache.values();
|
||||||
|
for (Player player : players) {
|
||||||
|
System.out.println("player: " + player.getName());
|
||||||
|
em.persist(player);
|
||||||
|
}
|
||||||
|
for (MapBoard mapboard : mapBoards) {
|
||||||
|
System.out.println("mapboard: " + mapboard.getMapName());
|
||||||
|
em.persist(mapboard);
|
||||||
|
}
|
||||||
|
em.getTransaction().commit();
|
||||||
|
}
|
||||||
|
|
||||||
public List<Player> getAllPlayersFromCache() {
|
public List<Player> getAllPlayersFromCache() {
|
||||||
checkTimeElapse();
|
checkTimeElapse();
|
||||||
return new ArrayList(playerCache.values());
|
return new ArrayList(playerCache.values());
|
||||||
|
@ -26,15 +26,17 @@ public class TimerResource {
|
|||||||
|
|
||||||
@GET
|
@GET
|
||||||
@Produces(MediaType.APPLICATION_JSON)
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
@Path("leaderboard")
|
@Path("leaderboard/{iterator}")
|
||||||
public String retrieveLeaderBoard() {
|
public String retrieveLeaderBoard(@PathParam("iterator") int iterator) {
|
||||||
return gson.toJson(facade.getleaderBoard());
|
facade.checkTimeElapse();
|
||||||
|
return gson.toJson(facade.getleaderBoard(iterator));
|
||||||
}
|
}
|
||||||
|
|
||||||
@GET
|
@GET
|
||||||
@Produces(MediaType.APPLICATION_JSON)
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
@Path("player/{steamid}")
|
@Path("player/{steamid}")
|
||||||
public String retrievePlayer(@PathParam("steamid") String steamid) {
|
public String retrievePlayer(@PathParam("steamid") String steamid) {
|
||||||
|
facade.checkTimeElapse();
|
||||||
return gson.toJson(facade.getPlayer(steamid));
|
return gson.toJson(facade.getPlayer(steamid));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -53,4 +55,12 @@ public class TimerResource {
|
|||||||
facade.checkTimeElapse();
|
facade.checkTimeElapse();
|
||||||
return gson.toJson(facade.getSpecificMap(mapname, stage));
|
return gson.toJson(facade.getSpecificMap(mapname, stage));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@GET
|
||||||
|
@Produces(MediaType.APPLICATION_JSON)
|
||||||
|
@Path("allmaps")
|
||||||
|
public String getAllMaps() {
|
||||||
|
facade.checkTimeElapse();
|
||||||
|
return gson.toJson(facade.getAllMaps());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ import { HashRouter as Router, Route } from "react-router-dom";
|
|||||||
import Leaderboard from "./Leaderboard/Leaderboard";
|
import Leaderboard from "./Leaderboard/Leaderboard";
|
||||||
import Player from "./Player/Player";
|
import Player from "./Player/Player";
|
||||||
import Maps from "./Maps/Maps";
|
import Maps from "./Maps/Maps";
|
||||||
|
import MapBoard from "./MapBoard/MapBoard";
|
||||||
|
|
||||||
class App extends Component {
|
class App extends Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
@ -30,6 +31,9 @@ class App extends Component {
|
|||||||
<Route path={`/map/:mapname/:stage`} render={(props) => {
|
<Route path={`/map/:mapname/:stage`} render={(props) => {
|
||||||
return (<Maps {...props} />)
|
return (<Maps {...props} />)
|
||||||
}} />
|
}} />
|
||||||
|
<Route path={`/mapboard`} render={(props) => {
|
||||||
|
return (<MapBoard {...props} />)
|
||||||
|
}} />
|
||||||
</Router>
|
</Router>
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
)
|
)
|
||||||
|
@ -1,19 +1,9 @@
|
|||||||
|
import React from 'react';
|
||||||
const URLleaderboard = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/leaderboard";
|
const URLleaderboard = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/leaderboard";
|
||||||
const URLPlayer = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/player/";
|
const URLPlayer = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/player/";
|
||||||
const URLPlayerMaps = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/player/maps/";
|
const URLPlayerMaps = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/player/maps/";
|
||||||
const URLMaps = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/map/";
|
const URLMaps = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/map/";
|
||||||
function makeOptions(method, body) {
|
const URLAllMaps = "http://localhost:8080/racetimer_endpoints-1.0/api/timers/allmaps";
|
||||||
var opts = {
|
|
||||||
method: method,
|
|
||||||
headers: {
|
|
||||||
"Content-type": "application/json"
|
|
||||||
}
|
|
||||||
};
|
|
||||||
if (body) {
|
|
||||||
opts.body = JSON.stringify(body);
|
|
||||||
}
|
|
||||||
return opts;
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleHttpErrors(res) {
|
function handleHttpErrors(res) {
|
||||||
if (!res.ok) {
|
if (!res.ok) {
|
||||||
@ -22,22 +12,123 @@ function handleHttpErrors(res) {
|
|||||||
return res.json();
|
return res.json();
|
||||||
}
|
}
|
||||||
|
|
||||||
class DataFacade {
|
class DataFacade extends React.Component {
|
||||||
getLeaderBoard = () => {
|
constructor(props) {
|
||||||
return fetch(URLleaderboard).then(handleHttpErrors);
|
super(props);
|
||||||
|
this.state = {
|
||||||
|
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
getLeaderBoardFromCache = async (incrementer) => {
|
||||||
|
const CachedTime = JSON.parse(localStorage.getItem("leaderboardTimer"));
|
||||||
|
const timeExpired = CachedTime ? Date.now() - CachedTime : 0;
|
||||||
|
//30 mins
|
||||||
|
if (!CachedTime || timeExpired > 30 * 60000) {
|
||||||
|
localStorage.setItem("leaderboardTimer", JSON.stringify(Date.now()));
|
||||||
|
localStorage.removeItem("leaderboard");
|
||||||
|
incrementer = 0;
|
||||||
|
}
|
||||||
|
var leaderBoardData = localStorage.getItem("leaderboard");
|
||||||
|
if (incrementer === 0 && leaderBoardData) {
|
||||||
|
const cachedLeaderBoard = JSON.parse(leaderBoardData);
|
||||||
|
return cachedLeaderBoard;
|
||||||
|
} else {
|
||||||
|
const players = await fetch(URLleaderboard + "/" + incrementer).then(handleHttpErrors);
|
||||||
|
if (leaderBoardData !== null) {
|
||||||
|
const cachedLeaderBoard = JSON.parse(leaderBoardData);
|
||||||
|
players.map(e => (
|
||||||
|
cachedLeaderBoard.push(e)
|
||||||
|
))
|
||||||
|
localStorage.setItem("leaderboard", JSON.stringify(cachedLeaderBoard));
|
||||||
|
return cachedLeaderBoard;
|
||||||
|
} else {
|
||||||
|
localStorage.setItem("leaderboard", JSON.stringify(players));
|
||||||
|
return players;
|
||||||
|
}
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
getPlayer = steamID => {
|
getAllMapsFromCache = async () => {
|
||||||
return fetch(URLPlayer + steamID).then(handleHttpErrors);
|
const CachedTime = JSON.parse(localStorage.getItem("allmapsTimer"));
|
||||||
|
const timeExpired = CachedTime ? Date.now() - CachedTime : 0;
|
||||||
|
//30 mins
|
||||||
|
if (!CachedTime || timeExpired > 30 * 60000) {
|
||||||
|
localStorage.setItem("allmapsTimer", JSON.stringify(Date.now()));
|
||||||
|
localStorage.removeItem("allmaps");
|
||||||
|
}
|
||||||
|
var allMapsData = localStorage.getItem("allmaps");
|
||||||
|
if (allMapsData) {
|
||||||
|
const cachedAllMaps = JSON.parse(allMapsData);
|
||||||
|
return cachedAllMaps;
|
||||||
|
} else {
|
||||||
|
const allMaps = await fetch(URLAllMaps).then(handleHttpErrors);
|
||||||
|
localStorage.setItem("allmaps", JSON.stringify(allMaps));
|
||||||
|
return allMaps;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
getPlayerFromCache = async (steamID) => {
|
||||||
|
const CachedTime = JSON.parse(localStorage.getItem("initialCachedplayers" + steamID));
|
||||||
|
const timeExpired = CachedTime ? Date.now() - CachedTime : 0;
|
||||||
|
//30 mins
|
||||||
|
if (!CachedTime || timeExpired > 30 * 60000) {
|
||||||
|
localStorage.setItem("initialCachedplayers" + steamID, JSON.stringify(Date.now()));
|
||||||
|
localStorage.removeItem("player/" + steamID)
|
||||||
|
}
|
||||||
|
var storageString = "player/" + steamID;
|
||||||
|
const playerData = localStorage.getItem(storageString);
|
||||||
|
if (playerData) {
|
||||||
|
const player = JSON.parse(playerData);
|
||||||
|
return player;
|
||||||
|
} else {
|
||||||
|
const player = await fetch(URLPlayer + steamID).then(handleHttpErrors);
|
||||||
|
localStorage.setItem(storageString, JSON.stringify(player));
|
||||||
|
return player;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getPlayerTimes = steamID => {
|
getPlayerTimesFromCache = async (steamID) => {
|
||||||
return fetch(URLPlayerMaps + steamID).then(handleHttpErrors);
|
const CachedTime = JSON.parse(localStorage.getItem("initialCachedplayersTimes" + steamID));
|
||||||
|
const timeExpired = CachedTime ? Date.now() - CachedTime : 0;
|
||||||
|
//30 mins
|
||||||
|
if (!CachedTime || timeExpired > 30 * 60000) {
|
||||||
|
localStorage.setItem("initialCachedplayersTimes" + steamID, JSON.stringify(Date.now()));
|
||||||
|
localStorage.removeItem("playertimes/" + steamID)
|
||||||
|
}
|
||||||
|
var storageString = "playertimes/" + steamID;
|
||||||
|
var playerTimesData = localStorage.getItem(storageString);
|
||||||
|
if (playerTimesData) {
|
||||||
|
const cachedPlayerTimes = JSON.parse(playerTimesData)
|
||||||
|
return cachedPlayerTimes;
|
||||||
|
} else {
|
||||||
|
const playertimes = await fetch(URLPlayerMaps + steamID).then(handleHttpErrors);
|
||||||
|
localStorage.setItem(storageString, JSON.stringify(playertimes));
|
||||||
|
return playertimes;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getMapTimes = (mapname, stage) => {
|
getMapTimesFromCache = async (mapname, stage) => {
|
||||||
return fetch(URLMaps + mapname + "/" + stage).then(handleHttpErrors);
|
const CachedTime = JSON.parse(localStorage.getItem("maptimescached" + mapname + stage));
|
||||||
|
const timeExpired = CachedTime ? Date.now() - CachedTime : 0;
|
||||||
|
//30 mins
|
||||||
|
if (!CachedTime || timeExpired > 30 * 60000) {
|
||||||
|
localStorage.setItem("maptimescached" + mapname + stage, JSON.stringify(Date.now()));
|
||||||
|
localStorage.removeItem("map/" + mapname + stage);
|
||||||
}
|
}
|
||||||
|
var mapTimesData = localStorage.getItem("map/" + mapname + stage);
|
||||||
|
if (mapTimesData) {
|
||||||
|
const cachedMapTimes = JSON.parse(mapTimesData);
|
||||||
|
return cachedMapTimes;
|
||||||
|
} else {
|
||||||
|
const mapTimes = await fetch(URLMaps + mapname + "/" + stage).then(handleHttpErrors);
|
||||||
|
localStorage.setItem("map/" + mapname + stage, JSON.stringify(mapTimes));
|
||||||
|
return mapTimes;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export default new DataFacade();
|
export default new DataFacade();
|
@ -1,48 +1,87 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Facade from '../Datafacade/datafacade';
|
import Facade from '../Datafacade/datafacade';
|
||||||
import { NavLink } from 'react-router-dom'
|
import { NavLink } from 'react-router-dom';
|
||||||
|
|
||||||
class Leaderboard extends React.Component {
|
class Leaderboard extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props)
|
super(props)
|
||||||
this.state = {
|
this.state = {
|
||||||
players: []
|
players: [],
|
||||||
|
breakload: true,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
componentWillMount() {
|
||||||
|
this.scrollListener = window.addEventListener("scroll", e => {
|
||||||
|
this.handleScroll(e);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
componentDidMount = async () => {
|
componentDidMount = async () => {
|
||||||
const players = await Facade.getLeaderBoard();
|
this.setState({ breakload: false })
|
||||||
|
const players = await Facade.getLeaderBoardFromCache(0);
|
||||||
|
this.setState({ breakload: true })
|
||||||
this.setState({ players });
|
this.setState({ players });
|
||||||
this.props.setLeaderboard(players);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
findSecondLast(array) {
|
||||||
|
return array[array.length - 2];
|
||||||
|
}
|
||||||
|
|
||||||
|
handleScroll = () => {
|
||||||
|
const player = this.findSecondLast(this.state.players);
|
||||||
|
var lastLi = document.getElementById('leaderboard/' + player.steamID);
|
||||||
|
var lastLiOffset = lastLi.offsetTop + lastLi.clientHeight;
|
||||||
|
var pageOffset = window.pageYOffset + window.innerHeight;
|
||||||
|
if (pageOffset > lastLiOffset && this.state.breakload) {
|
||||||
|
this.setState({ breakload: false })
|
||||||
|
this.loadPlayers();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
loadPlayers = async () => {
|
||||||
|
const players = await Facade.getLeaderBoardFromCache(this.state.players.length + 1);
|
||||||
|
this.setState({ players });
|
||||||
|
this.setState({ breakload: true })
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
|
<ul>
|
||||||
<div className="container mm" style={{ marginTop: "85px" }}>
|
<div className="container mm" style={{ marginTop: "85px" }}>
|
||||||
<div style={{
|
<div style={{
|
||||||
position: 'absolute', left: '50%', top: '30%'
|
position: 'absolute', left: '50%', top: '30%'
|
||||||
}}>
|
}}>
|
||||||
|
<NavLink to={'/mapboard/'}>
|
||||||
|
<h3> <strong className="col-lg-1 col-centered" /> MapBoard<br /> </h3>
|
||||||
|
</NavLink>
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
{this.state.players.map(e => (
|
{this.state.players.map(e => (
|
||||||
<div>
|
<li key={e.steamID} id={"leaderboard/" + e.steamID}>
|
||||||
<NavLink to={'/player/' + e.steamID}>
|
<NavLink to={'/player/' + e.steamID}>
|
||||||
<strong class="col-lg-1 col-centered" /> {e.steamID}<br />
|
<strong className="col-lg-1 col-centered" /> {e.steamID}<br />
|
||||||
<strong class="col-lg-1 col-centered" />{e.name}<br />
|
<strong className="col-lg-1 col-centered" />{e.name}<br />
|
||||||
<img src={e.Avatar} /> <br />
|
<img src={e.Avatar} alt="" /> <br />
|
||||||
<strong class="col-lg-1 col-centered" />Rank: {e.Rank}<br />
|
<strong className="col-lg-1 col-centered" />Rank: {e.Rank}<br />
|
||||||
<strong class="col-lg-1 col-centered" />Points: {e.PlayerPoints}<br />
|
<strong className="col-lg-1 col-centered" />Points: {e.PlayerPoints}<br />
|
||||||
<strong class="col-lg-1 col-centered" />Times: {e.Times}<br />
|
<strong className="col-lg-1 col-centered" />Times: {e.Times}<br />
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
</NavLink>
|
</NavLink>
|
||||||
</div>
|
</li>
|
||||||
))}
|
))}
|
||||||
|
{!this.state.breakload ? <h1> <br /> <br /><p className="loading">
|
||||||
|
Loading More Players...
|
||||||
|
</p> </h1> : ""}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</ul>
|
||||||
</React.Fragment>
|
</React.Fragment>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
export default Leaderboard;
|
export default Leaderboard;
|
48
RaceTimer/racetimer_react/src/MapBoard/MapBoard.js
Normal file
48
RaceTimer/racetimer_react/src/MapBoard/MapBoard.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import Facade from '../Datafacade/datafacade';
|
||||||
|
import { NavLink } from 'react-router-dom';
|
||||||
|
|
||||||
|
class MapBoards extends React.Component {
|
||||||
|
|
||||||
|
constructor(props) {
|
||||||
|
super(props)
|
||||||
|
this.state = {
|
||||||
|
maps: []
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
componentWillMount = async () => {
|
||||||
|
const maps = await Facade.getAllMapsFromCache();
|
||||||
|
this.setState({ maps });
|
||||||
|
};
|
||||||
|
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<React.Fragment>
|
||||||
|
<div className="container mm" style={{ marginTop: "85px" }}>
|
||||||
|
<div style={{
|
||||||
|
position: 'absolute', left: '50%', top: '30%'
|
||||||
|
}}>
|
||||||
|
<NavLink to={'/leaderboard/'}>
|
||||||
|
<h3> <strong class="col-lg-1 col-centered" /> leaderboard<br /> </h3>
|
||||||
|
</NavLink>
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
{this.state.maps.map(e => (
|
||||||
|
<div>
|
||||||
|
<NavLink to={'/map/' + e.mapname + "/" + e.mapstage}>
|
||||||
|
<strong class="col-lg-1 col-centered" /> Map: {e.mapname}<br />
|
||||||
|
<strong class="col-lg-1 col-centered" /> Stage: {e.mapstage}<br />
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
|
</NavLink>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
/</div>
|
||||||
|
</div>
|
||||||
|
</React.Fragment>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
export default MapBoards;
|
@ -1,5 +1,6 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Facade from '../Datafacade/datafacade';
|
import Facade from '../Datafacade/datafacade';
|
||||||
|
import { NavLink } from 'react-router-dom';
|
||||||
|
|
||||||
class Maps extends React.Component {
|
class Maps extends React.Component {
|
||||||
|
|
||||||
@ -14,7 +15,7 @@ class Maps extends React.Component {
|
|||||||
componentWillMount = async () => {
|
componentWillMount = async () => {
|
||||||
const mapname = this.props.match.params.mapname;
|
const mapname = this.props.match.params.mapname;
|
||||||
const stage = this.props.match.params.stage;
|
const stage = this.props.match.params.stage;
|
||||||
const mapTimes = await Facade.getMapTimes(mapname, stage);
|
const mapTimes = await Facade.getMapTimesFromCache(mapname, stage);
|
||||||
this.setState({ mapTimes });
|
this.setState({ mapTimes });
|
||||||
this.setState({ mapName: mapname })
|
this.setState({ mapName: mapname })
|
||||||
};
|
};
|
||||||
@ -22,25 +23,40 @@ class Maps extends React.Component {
|
|||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
|
<div className="alert alert-primary" >
|
||||||
|
<NavLink to={'/leaderboard/'}>
|
||||||
|
<h3> <strong className="col-lg-1 col-centered" /> leaderboard<br /> </h3>
|
||||||
|
</NavLink>
|
||||||
|
<NavLink to={'/mapboard/'}>
|
||||||
|
<h3> <strong className="col-lg-1 col-centered" /> MapBoard<br /> </h3>
|
||||||
|
</NavLink>
|
||||||
|
</div>
|
||||||
<div className="container mm" style={{ marginTop: "85px" }}>
|
<div className="container mm" style={{ marginTop: "85px" }}>
|
||||||
<div style={{
|
<div style={{
|
||||||
position: 'absolute', left: '50%', top: '30%'
|
position: 'absolute', left: '50%', top: '30%'
|
||||||
}}>
|
}}>
|
||||||
|
|
||||||
|
<br />
|
||||||
|
<br />
|
||||||
<div>
|
<div>
|
||||||
<strong class="col-lg-1 col-centered" />{this.state.mapName}<br />
|
<strong className="col-lg-1 col-centered" />{this.state.mapName}<br />
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
{this.state.mapTimes.map(e => (
|
{this.state.mapTimes.map(e => (
|
||||||
<div>
|
<div className="item" key={e.steamID}>
|
||||||
<strong class="col-lg-1 col-centered" /> Position: {e.position}<br />
|
<div className="box_grid">
|
||||||
<strong class="col-lg-1 col-centered" /> SteamID: {e.steamID}<br />
|
<NavLink to={'/player/' + e.steamID}>
|
||||||
<strong class="col-lg-1 col-centered" /> Name: {e.name}<br />
|
<strong className="col-lg-1 col-centered" /> SteamID: {e.steamID}<br />
|
||||||
<strong class="col-lg-1 col-centered" /> Mappoints: {e.mapPoint}<br />
|
<strong className="col-lg-1 col-centered" /> Name: {e.name}<br />
|
||||||
<strong class="col-lg-1 col-centered" /> Time: 0{e.mapTimeMinutes}:{e.mapTimeSeconds}<br />
|
<img src={e.avatar} alt=""/> <br />
|
||||||
|
</NavLink>
|
||||||
|
<strong className="col-lg-1 col-centered" /> Position: {e.position}<br />
|
||||||
|
<strong className="col-lg-1 col-centered" /> Mappoints: {e.mapPoint}<br />
|
||||||
|
<strong className="col-lg-1 col-centered" /> Time: 0{e.mapTimeMinutes}:{e.mapTimeSeconds}<br />
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
))}
|
))}
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,20 +1,21 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Facade from '../Datafacade/datafacade';
|
import Facade from '../Datafacade/datafacade';
|
||||||
import { NavLink } from 'react-router-dom'
|
import { NavLink } from 'react-router-dom';
|
||||||
|
|
||||||
class Player extends React.Component {
|
class Player extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props)
|
super(props)
|
||||||
this.state = {
|
this.state = {
|
||||||
player: {},
|
player: {},
|
||||||
mapTimes: []
|
mapTimes: [],
|
||||||
|
breakload: true,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
componentWillMount = async () => {
|
componentWillMount = async () => {
|
||||||
const steamid = this.props.match.params.steamid;
|
const steamid = this.props.match.params.steamid;
|
||||||
const player = await Facade.getPlayer(steamid);
|
const player = await Facade.getPlayerFromCache(steamid);
|
||||||
const mapTimes = await Facade.getPlayerTimes(steamid);
|
const mapTimes = await Facade.getPlayerTimesFromCache(steamid);
|
||||||
this.setState({ player });
|
this.setState({ player });
|
||||||
this.setState({ mapTimes });
|
this.setState({ mapTimes });
|
||||||
};
|
};
|
||||||
@ -28,23 +29,23 @@ class Player extends React.Component {
|
|||||||
}}>
|
}}>
|
||||||
<div>
|
<div>
|
||||||
<a href={"http://steamcommunity.com/profiles/" + this.state.player.steamID64}>
|
<a href={"http://steamcommunity.com/profiles/" + this.state.player.steamID64}>
|
||||||
<strong class="col-lg-1 col-centered" /> {this.state.player.steamID}<br />
|
<strong className="col-lg-1 col-centered" /> {this.state.player.steamID}<br />
|
||||||
<strong class="col-lg-1 col-centered" />{this.state.player.name}<br />
|
<strong className="col-lg-1 col-centered" />{this.state.player.name}<br />
|
||||||
<img src={this.state.player.Avatar} /> <br />
|
<img src={this.state.player.Avatar} alt="" /> <br />
|
||||||
<strong class="col-lg-1 col-centered" />Rank: {this.state.player.Rank}<br />
|
<strong className="col-lg-1 col-centered" />Rank: {this.state.player.Rank}<br />
|
||||||
<strong class="col-lg-1 col-centered" />Points: {this.state.player.PlayerPoints}<br />
|
<strong className="col-lg-1 col-centered" />Points: {this.state.player.PlayerPoints}<br />
|
||||||
<strong class="col-lg-1 col-centered" />Times: {this.state.player.Times}<br />
|
<strong className="col-lg-1 col-centered" />Times: {this.state.player.Times}<br />
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
</a>
|
</a>
|
||||||
{this.state.mapTimes.map(e => (
|
{this.state.mapTimes.map(e => (
|
||||||
<div>
|
<div key={"mapkey/" + e.mapname + "/" + e.mapstage}>
|
||||||
<NavLink to={'/map/' + e.mapname + "/" + e.mapstage}>
|
<NavLink to={'/map/' + e.mapname + "/" + e.mapstage}>
|
||||||
<strong class="col-lg-1 col-centered" /> Map: {e.mapname}<br />
|
<strong className="col-lg-1 col-centered" /> Map: {e.mapname}<br />
|
||||||
<strong class="col-lg-1 col-centered" /> Stage: {e.mapstage}<br />
|
<strong className="col-lg-1 col-centered" /> Stage: {e.mapstage}<br />
|
||||||
<strong class="col-lg-1 col-centered" /> Position: {e.position}<br />
|
<strong className="col-lg-1 col-centered" /> Position: {e.position}<br />
|
||||||
<strong class="col-lg-1 col-centered" /> Time: 0{e.mapTimeMinutes}:{e.mapTimeSeconds}<br />
|
<strong className="col-lg-1 col-centered" /> Time: 0{e.mapTimeMinutes}:{e.mapTimeSeconds}<br />
|
||||||
<strong class="col-lg-1 col-centered" /> MapPoints: {e.mapPoint}<br />
|
<strong className="col-lg-1 col-centered" /> MapPoints: {e.mapPoint}<br />
|
||||||
<br />
|
<br />
|
||||||
<br />
|
<br />
|
||||||
</NavLink>
|
</NavLink>
|
||||||
|
0
RaceTimer/racetimer_react/src/css/App.css
Normal file
0
RaceTimer/racetimer_react/src/css/App.css
Normal file
19928
RaceTimer/racetimer_react/src/css/custom.css
Normal file
19928
RaceTimer/racetimer_react/src/css/custom.css
Normal file
File diff suppressed because it is too large
Load Diff
7587
RaceTimer/racetimer_react/src/css/style.css
Normal file
7587
RaceTimer/racetimer_react/src/css/style.css
Normal file
File diff suppressed because it is too large
Load Diff
19926
RaceTimer/racetimer_react/src/css/vendors.css
Normal file
19926
RaceTimer/racetimer_react/src/css/vendors.css
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user