|
@ -1,15 +1,15 @@ |
|
|
<script lang="ts"> |
|
|
<script lang="ts"> |
|
|
import Navbar from './components/NavBar.svelte'; |
|
|
import Navbar from "./components/NavBar.svelte"; |
|
|
import Profile from './components/Profile.svelte'; |
|
|
import Profile from "./components/Profile.svelte"; |
|
|
import MatchHistory from './components/MatchHistory.svelte'; |
|
|
import MatchHistory from "./components/MatchHistory.svelte"; |
|
|
import type { Match } from './components/MatchHistory.svelte'; |
|
|
import type { Match } from "./components/MatchHistory.svelte"; |
|
|
import Friends from './components/Friends.svelte'; |
|
|
import Friends from "./components/Friends.svelte"; |
|
|
import type { Friend } from './components/Friends.svelte'; |
|
|
import type { Friend } from "./components/Friends.svelte"; |
|
|
import Spectate from './components/Spectate.svelte'; |
|
|
import Spectate from "./components/Spectate.svelte"; |
|
|
import type { SpectateType } from './components/Spectate.svelte'; |
|
|
import type { SpectateType } from "./components/Spectate.svelte"; |
|
|
import Play from './components/Play.svelte'; |
|
|
import Play from "./components/Play.svelte"; |
|
|
import Pong from './components/Pong/Pong.svelte'; |
|
|
import Pong from "./components/Pong/Pong.svelte"; |
|
|
import Chat from './components/Chat.svelte' |
|
|
import Chat from "./components/Chat.svelte"; |
|
|
|
|
|
|
|
|
let isProfileOpen = false; |
|
|
let isProfileOpen = false; |
|
|
function clickProfile() { |
|
|
function clickProfile() { |
|
@ -20,59 +20,78 @@ |
|
|
isHistoryOpen = true; |
|
|
isHistoryOpen = true; |
|
|
} |
|
|
} |
|
|
let matches: Array<Match> = [ |
|
|
let matches: Array<Match> = [ |
|
|
{ winner: 'Alice', loser: 'Bob', points: -5, rank: '22' }, |
|
|
{ winner: "Alice", loser: "Bob", points: -5, rank: "22" }, |
|
|
{ winner: 'Alice', loser: 'Bob', points: 10, rank: '24' }, |
|
|
{ winner: "Alice", loser: "Bob", points: 10, rank: "24" }, |
|
|
{ winner: 'Alice', loser: 'Bob', points: 10, rank: '24' }, |
|
|
{ winner: "Alice", loser: "Bob", points: 10, rank: "24" }, |
|
|
{ winner: 'Alice', loser: 'Bob', points: 7, rank: '23' }, |
|
|
{ winner: "Alice", loser: "Bob", points: 7, rank: "23" }, |
|
|
{ winner: 'Alice', loser: 'Bob', points: 10, rank: '24' }, |
|
|
{ winner: "Alice", loser: "Bob", points: 10, rank: "24" }, |
|
|
{ winner: 'Alice', loser: 'Bob', points: 10, rank: '24' } |
|
|
{ winner: "Alice", loser: "Bob", points: 10, rank: "24" }, |
|
|
]; |
|
|
]; |
|
|
let isFriendOpen = false; |
|
|
let isFriendOpen = false; |
|
|
function clickFriends() { |
|
|
function clickFriends() { |
|
|
isFriendOpen = true; |
|
|
isFriendOpen = true; |
|
|
} |
|
|
} |
|
|
let friends: Array<Friend> = [ |
|
|
let friends: Array<Friend> = [ |
|
|
{ username: 'Alice', status: 'online' }, |
|
|
{ username: "Alice", status: "online" }, |
|
|
{ username: 'Bob', status: 'online' }, |
|
|
{ username: "Bob", status: "online" }, |
|
|
{ username: 'Charlie', status: 'offline' }, |
|
|
{ username: "Charlie", status: "offline" }, |
|
|
{ username: 'Dave', status: 'offline' }, |
|
|
{ username: "Dave", status: "offline" }, |
|
|
{ username: 'Eve', status: 'in a game' }, |
|
|
{ username: "Eve", status: "in a game" }, |
|
|
{ username: 'Frank', status: 'online' } |
|
|
{ username: "Frank", status: "online" }, |
|
|
]; |
|
|
]; |
|
|
let isSpectateOpen = false; |
|
|
let isSpectateOpen = false; |
|
|
function clickSpectate() { |
|
|
function clickSpectate() { |
|
|
isSpectateOpen = true; |
|
|
isSpectateOpen = true; |
|
|
} |
|
|
} |
|
|
let spectate: Array<SpectateType> = [ |
|
|
let spectate: Array<SpectateType> = [ |
|
|
{ player1: 'Alice', player2: 'Bob', id: '1' }, |
|
|
{ player1: "Alice", player2: "Bob", id: "1" }, |
|
|
{ player1: 'Alice', player2: 'Bob', id: '4' }, |
|
|
{ player1: "Alice", player2: "Bob", id: "4" }, |
|
|
{ player1: 'Alice', player2: 'Bob', id: '6' }, |
|
|
{ player1: "Alice", player2: "Bob", id: "6" }, |
|
|
{ player1: 'Alice', player2: 'Bob', id: '8' }, |
|
|
{ player1: "Alice", player2: "Bob", id: "8" }, |
|
|
{ player1: 'Alice', player2: 'Bob', id: '2' }, |
|
|
{ player1: "Alice", player2: "Bob", id: "2" }, |
|
|
{ player1: 'Alice', player2: 'Bob', id: '3' } |
|
|
{ player1: "Alice", player2: "Bob", id: "3" }, |
|
|
]; |
|
|
]; |
|
|
</script> |
|
|
</script> |
|
|
|
|
|
|
|
|
<main> |
|
|
<main> |
|
|
<Navbar {clickProfile} {clickHistory} {clickFriends} {clickSpectate} /> |
|
|
<Navbar {clickProfile} {clickHistory} {clickFriends} {clickSpectate} /> |
|
|
{#if isSpectateOpen} |
|
|
{#if isSpectateOpen} |
|
|
<div on:click={() => (isSpectateOpen = false)} on:keydown={() => (isSpectateOpen = false)}> |
|
|
<div |
|
|
|
|
|
on:click={() => (isSpectateOpen = false)} |
|
|
|
|
|
on:keydown={() => (isSpectateOpen = false)} |
|
|
|
|
|
> |
|
|
<Spectate {spectate} /> |
|
|
<Spectate {spectate} /> |
|
|
</div> |
|
|
</div> |
|
|
{/if} |
|
|
{/if} |
|
|
{#if isFriendOpen} |
|
|
{#if isFriendOpen} |
|
|
<div on:click={() => (isFriendOpen = false)} on:keydown={() => (isFriendOpen = false)}> |
|
|
<div |
|
|
|
|
|
on:click={() => (isFriendOpen = false)} |
|
|
|
|
|
on:keydown={() => (isFriendOpen = false)} |
|
|
|
|
|
> |
|
|
<Friends {friends} /> |
|
|
<Friends {friends} /> |
|
|
</div> |
|
|
</div> |
|
|
{/if} |
|
|
{/if} |
|
|
{#if isHistoryOpen} |
|
|
{#if isHistoryOpen} |
|
|
<div on:click={() => (isHistoryOpen = false)} on:keydown={() => (isHistoryOpen = false)}> |
|
|
<div |
|
|
|
|
|
on:click={() => (isHistoryOpen = false)} |
|
|
|
|
|
on:keydown={() => (isHistoryOpen = false)} |
|
|
|
|
|
> |
|
|
<MatchHistory {matches} /> |
|
|
<MatchHistory {matches} /> |
|
|
</div> |
|
|
</div> |
|
|
{/if} |
|
|
{/if} |
|
|
{#if isProfileOpen} |
|
|
{#if isProfileOpen} |
|
|
<div on:click={() => (isProfileOpen = false)} on:keydown={() => (isProfileOpen = false)}> |
|
|
<div |
|
|
<Profile username="Alice" wins={10} losses={5} elo={256} rank={23} is2faEnabled={false} /> |
|
|
on:click={() => (isProfileOpen = false)} |
|
|
|
|
|
on:keydown={() => (isProfileOpen = false)} |
|
|
|
|
|
> |
|
|
|
|
|
<Profile |
|
|
|
|
|
username="Alice" |
|
|
|
|
|
wins={10} |
|
|
|
|
|
losses={5} |
|
|
|
|
|
elo={256} |
|
|
|
|
|
rank={23} |
|
|
|
|
|
is2faEnabled={false} |
|
|
|
|
|
/> |
|
|
</div> |
|
|
</div> |
|
|
{/if} |
|
|
{/if} |
|
|
<Play /> |
|
|
<Play /> |
|
|