diff options
| author | Arda Serdar Pektezol <1669855+pektezol@users.noreply.github.com> | 2025-10-27 22:12:56 +0300 |
|---|---|---|
| committer | Arda Serdar Pektezol <1669855+pektezol@users.noreply.github.com> | 2025-10-27 23:13:45 +0400 |
| commit | dd5ea1b1fcbb21c919a16bc70c6507b097c12f6b (patch) | |
| tree | eba2d3b52bc26021ac31d76477e3ac672d1db096 /frontend/src/api/Stats.ts | |
| parent | feat/backend: timeline stats endpoint (diff) | |
| download | lphub-dd5ea1b1fcbb21c919a16bc70c6507b097c12f6b.tar.gz lphub-dd5ea1b1fcbb21c919a16bc70c6507b097c12f6b.tar.bz2 lphub-dd5ea1b1fcbb21c919a16bc70c6507b097c12f6b.zip | |
feat/frontend: homepage with timeline and recent scores
Diffstat (limited to '')
| -rw-r--r-- | frontend/src/api/Stats.ts | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/frontend/src/api/Stats.ts b/frontend/src/api/Stats.ts new file mode 100644 index 0000000..21654b5 --- /dev/null +++ b/frontend/src/api/Stats.ts | |||
| @@ -0,0 +1,52 @@ | |||
| 1 | import axios from "axios"; | ||
| 2 | import { url } from "./Api"; | ||
| 3 | |||
| 4 | export interface PortalCountData { | ||
| 5 | date: string; | ||
| 6 | count: number; | ||
| 7 | } | ||
| 8 | |||
| 9 | export interface RecordsTimelineResponse { | ||
| 10 | timeline_singleplayer: PortalCountData[]; | ||
| 11 | timeline_multiplayer: PortalCountData[]; | ||
| 12 | } | ||
| 13 | |||
| 14 | export interface ScoreLog { | ||
| 15 | game: { | ||
| 16 | id: number; | ||
| 17 | name: string; | ||
| 18 | image: string; | ||
| 19 | is_coop: boolean; | ||
| 20 | category_portals: null; | ||
| 21 | }; | ||
| 22 | user: { | ||
| 23 | steam_id: string; | ||
| 24 | user_name: string; | ||
| 25 | }; | ||
| 26 | map: { | ||
| 27 | id: number; | ||
| 28 | name: string; | ||
| 29 | image: string; | ||
| 30 | is_disabled: boolean; | ||
| 31 | portal_count: number; | ||
| 32 | difficulty: number; | ||
| 33 | }; | ||
| 34 | score_count: number; | ||
| 35 | } | ||
| 36 | |||
| 37 | export async function get_portal_count_history(): Promise<RecordsTimelineResponse | undefined> { | ||
| 38 | const response = await axios.get(url("stats/timeline")); | ||
| 39 | if (!response.data.data) { | ||
| 40 | return undefined; | ||
| 41 | } | ||
| 42 | return response.data.data; | ||
| 43 | } | ||
| 44 | |||
| 45 | export async function get_recent_scores(): Promise<ScoreLog[]> { | ||
| 46 | const response = await axios.get(url("stats/scores")); | ||
| 47 | if (!response.data.data) { | ||
| 48 | return []; | ||
| 49 | } | ||
| 50 | return response.data.data.scores.slice(0, 5); | ||
| 51 | } | ||
| 52 | |||