diff --git a/package.json b/package.json index a05fec3..af31ae0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "g5v", - "version": "1.7.0", + "version": "1.7.1", "private": true, "scripts": { "serve": "vue-cli-service serve", diff --git a/src/components/PlayerStatTable.vue b/src/components/PlayerStatTable.vue index d826515..5fd54aa 100644 --- a/src/components/PlayerStatTable.vue +++ b/src/components/PlayerStatTable.vue @@ -8,40 +8,40 @@
- {{ arrMapString[index].score }} - {{ arrMapString[index].map }} + {{ mapStats[index].score }} - {{ mapStats[index].map }}
- {{ arrMapString[index].start }} + {{ mapStats[index].start }}
- {{ arrMapString[index].end }} + {{ mapStats[index].end }}
{{ $t("PlayerStats.Download") }} @@ -49,7 +49,7 @@
@@ -113,7 +113,7 @@ export default { return { playerstats: [], isLoading: true, - arrMapString: [{}], + mapStats: [], allowRefresh: false, timeoutId: -1, isFinished: false, @@ -122,7 +122,6 @@ export default { }, created() { this.useStreamOrStaticData(); - this.getMapString(); }, computed: { headers() { @@ -239,8 +238,14 @@ export default { async useStreamOrStaticData() { // Template will contain v-rows/etc like on main Team page. let matchData = await this.GetMatchData(this.match_id); - if (matchData.end_time == null) this.GetMapPlayerStatsStream(matchData); - else this.GetMapPlayerStats(matchData); + if (matchData.end_time == null) { + this.GetMapStatsStream(matchData); + this.GetMapPlayerStatsStream(matchData); + } + else { + this.getMapString(matchData); + this.GetMapPlayerStats(matchData); + } }, async retrieveStatsHelper(serverResponse, matchData) { if (typeof serverResponse == "string") return; @@ -324,34 +329,55 @@ export default { } return; }, - async getMapString() { + async GetMapStatsStream(matchData) { try { - let mapStats = await this.GetMapStats(this.match_id); - if (typeof mapStats == "string") return; - mapStats.forEach((singleMapStat, index) => { - this.arrMapString[index] = {}; - this.arrMapString[index].score = - "Score: " + - singleMapStat.team1_score + - " " + - this.GetScoreSymbol( - singleMapStat.team1_score, - singleMapStat.team2_score - ) + - " " + - singleMapStat.team2_score; - this.arrMapString[index].start = - "Map Start: " + new Date(singleMapStat.start_time).toLocaleString(); - this.arrMapString[index].end = - singleMapStat.end_time == null - ? null - : "Map End: " + new Date(singleMapStat.end_time).toLocaleString(); - this.arrMapString[index].map = "Map: " + singleMapStat.map_name; - this.arrMapString[index].demo = singleMapStat.demoFile; + let sseClient = await this.GetEventMapStats(this.match_id); + await sseClient.connect(); + await sseClient.on("mapstats", async message => { + await this.retrieveMapStatsHelper(message,matchData); }); } catch (error) { - console.log("String error " + error); + console.log("Our error: " + error); + } finally { + this.isLoading = false; } + return; + }, + async getMapString(matchData) { + try { + let res = await this.GetMapStats(this.match_id); + await this.retrieveMapStatsHelper(res, matchData); + } catch (error) { + console.log("Our error: " + error); + } finally { + this.isLoading = false; + } + return; + }, + async retrieveMapStatsHelper(serverResponse, matchData) { + if (typeof serverResponse == "string") return; + await serverResponse.forEach((singleMapStat, index) => { + if (!this.mapStats[index]) { + this.$set(this.mapStats, index, {}); + } + + this.$set(this.mapStats[index], 'score', "Score: " + + singleMapStat.team1_score + + " " + + this.GetScoreSymbol( + singleMapStat.team1_score, + singleMapStat.team2_score + ) + + " " + + singleMapStat.team2_score); + this.$set(this.mapStats[index], 'start', "Map Start: " + new Date(singleMapStat.start_time).toLocaleString()); + this.$set(this.mapStats[index], 'end', singleMapStat.end_time == null ? + null : + "Map End: " + new Date(singleMapStat.end_time).toLocaleString()); + this.$set(this.mapStats[index], 'map', "Map: " + singleMapStat.map_name); + this.$set(this.mapStats[index], 'demo', singleMapStat.demoFile); + }); + if (matchData.end_time != null) this.isFinished = true; } } }; diff --git a/src/utils/api.vue b/src/utils/api.vue index ce7b24c..2a1090e 100644 --- a/src/utils/api.vue +++ b/src/utils/api.vue @@ -894,6 +894,19 @@ export default { } return message; }, + async GetEventMapStats(matchid) { + return this.$sse + .create({ + url: `${process.env?.VUE_APP_G5V_API_URL || + "/api"}/mapstats/${matchid}/stream`, + format: "json", + withCredentials: true, + polyfill: true + }) + .on("error", err => + console.error("Failed to parse or lost connection:", err) + ); + }, // END MAP STATS // BEGIN MATCH ADMIN CALLS async PauseMatch(matchid) {