Browse Source

view personals history in profiles

master
nicolas-arnaud 2 years ago
parent
commit
fb1b5e0bbd
  1. 32
      front/volume/src/App.svelte
  2. 7
      front/volume/src/components/Profile.svelte

32
front/volume/src/App.svelte

@ -3,6 +3,7 @@
HOME = "/",
PROFILE = "/profile",
HISTORY = "/history",
HISTORY_ID = "/history_id",
FRIENDS = "/friends",
SPECTATE = "/spectate",
CHANNELS = "/channels",
@ -61,6 +62,7 @@
setInterval(() => {
getUser();
}, 15000);
function clickProfile() {
setAppState(APPSTATE.PROFILE);
}
@ -80,12 +82,13 @@
}
// HISTORY
let matches: Array<Match>;
async function clickHistory() {
setAppState(APPSTATE.HISTORY);
matches = await getHistory();
}
let matches: Array<Match>;
export async function getHistory(): Promise<Array<Match>> {
let response = await fetch(API_URL + "/rankedHistory/", {
credentials: "include",
@ -94,19 +97,29 @@
return await response.json();
}
async function openIdHistory(event: CustomEvent<string>) {
console.log("Opening history: " + event.detail);
const res = await fetch(API_URL + "/history/" + event.detail, {
credentials: "include",
mode: "cors",
});
matches = await res.json();
setAppState(APPSTATE.HISTORY_ID);
}
// FRIENDS
let friends: Friend[] = [];
let invits: Friend[] = [];
let friendsInterval: ReturnType<typeof setInterval>;
export async function getFriends(): Promise<Friend[]> {
async function getFriends(): Promise<Friend[]> {
let response = await fetch(API_URL + "/friends", {
credentials: "include",
mode: "cors",
});
return await response.json();
}
export async function getInvits(): Promise<Friend[]> {
async function getInvits(): Promise<Friend[]> {
let response = await fetch(API_URL + "/invits", {
credentials: "include",
mode: "cors",
@ -235,14 +248,23 @@
<MatchHistory {matches} />
</div>
{/if}
{#if appState === APPSTATE.HISTORY_ID}
<div on:click={resetAppState} on:keydown={resetAppState}>
<MatchHistory {matches} />
</div>
{/if}
{#if appState === APPSTATE.PROFILE}
<div on:click={resetAppState} on:keydown={resetAppState}>
<Profile user={$store} edit={1} />
<Profile user={$store} edit={1}
on:view-history={openIdHistory}
/>
</div>
{/if}
{#if appState === APPSTATE.PROFILE_ID}
<div on:click={resetAppState} on:keydown={resetAppState}>
<Profile user={userProfile} edit={0} />
<Profile user={userProfile} edit={0}
on:view-history={openIdHistory}
/>
</div>
{/if}

7
front/volume/src/components/Profile.svelte

@ -11,11 +11,13 @@
</script>
<script lang="ts">
import { createEventDispatcher } from "svelte";
import { API_URL, store, logout } from "../Auth";
export let edit: number;
export let user: any;
const dispatch = createEventDispatcher();
async function handleSubmit() {
let response = await fetch(API_URL, {
headers: { "content-type": "application/json" },
@ -69,10 +71,12 @@
{/if}
</div>
<div class="profile-body">
<p><button on:click={() => dispatch("view-history", user.ftId)}>View History</button></p>
<p>Wins: {user.wins}</p>
<p>Looses: {user.looses}</p>
<p>Winrate: {user.winrate}%</p>
<p>Rank: {user.rank}</p>
</div>
{#if edit == 1}
<form
id="username-form"
@ -93,7 +97,6 @@
</button>
<button id="logout" type="button" on:click={logout}>Log Out</button>
{/if}
</div>
</div>
</div>
@ -143,7 +146,7 @@
justify-content: center;
}
.profile-body > p {
.profile-body >p {
display: flex;
justify-content: center;
}

Loading…
Cancel
Save