mirror of
https://github.com/psforever/PSFPortal.git
synced 2026-01-19 18:14:45 +00:00
86 lines
2.3 KiB
Svelte
86 lines
2.3 KiB
Svelte
<script>
|
|
import { onMount } from 'svelte';
|
|
import axios from 'axios'
|
|
import moment from 'moment'
|
|
|
|
import { loggedIn } from '../UserState'
|
|
import Alert from '../components/Alert'
|
|
import AccountLink from '../components/AccountLink'
|
|
import CharacterLink from '../components/CharacterLink'
|
|
import EmpireStats from '../components/EmpireStats'
|
|
|
|
export let ready;
|
|
|
|
let stats;
|
|
let alert;
|
|
let players;
|
|
|
|
function format_account(account) {
|
|
return `<a href="/user/${account.id}">${account.username}</a>`
|
|
}
|
|
|
|
onMount(async () => {
|
|
try {
|
|
const resp = await axios.get("/api/stats")
|
|
stats = resp.data;
|
|
players = stats.players
|
|
alert.message("")
|
|
} catch (e) {
|
|
console.log(e)
|
|
alert.message("Failed to fetch stats from server")
|
|
}
|
|
|
|
ready = true
|
|
})
|
|
</script>
|
|
|
|
<svelte:head>
|
|
<title>PSForever Portal</title>
|
|
</svelte:head>
|
|
|
|
<Alert bind:this={alert} />
|
|
|
|
{#if stats}
|
|
<div class="row">
|
|
<div class="col-md-8 col-12">
|
|
<h1>PSForever Live Server</h1>
|
|
|
|
<div class="row">
|
|
<div class="col">
|
|
{#if !$loggedIn}
|
|
<a class="btn btn-primary" href="/login" role="button">Login</a>
|
|
<a class="btn btn-primary" href="/register" role="button">Create Account</a>
|
|
{/if}
|
|
<a class="btn btn-secondary" href="https://docs.google.com/document/d/1ZMx1NUylVZCXJNRyhkuVWT0eUKSVYu0JXsU-y3f93BY/edit" role="button">Setup Instructions</a>
|
|
</div>
|
|
</div><br/>
|
|
|
|
<p>
|
|
<strong>Server address:</strong> <code>play.psforever.net:51000</code>
|
|
<button type="button" class="btn btn-sm" class:btn-success={stats.status == "UP"}
|
|
class:btn-danger={stats.status != "UP"}>Server {stats.status}</button><br/>
|
|
<strong>Last character created:</strong> <CharacterLink character={stats.last.character} /> (<span title={moment(stats.last.character.created).format(`MMMM Do YYYY, h:mm:ss a`)}>{moment(stats.last.character.created).fromNow()}</span>)<br/>
|
|
<strong># Accounts:</strong> {stats.accounts.toLocaleString()}<br/>
|
|
<strong># Characters:</strong> {stats.characters.toLocaleString()}
|
|
</p>
|
|
|
|
|
|
{#if players}
|
|
<h2>Online Players ({players.length})</h2>
|
|
<div class="row">
|
|
{#each players as char, i}
|
|
<div class="col-md-4 col-12"><CharacterLink character={char} /></div>
|
|
{/each}
|
|
</div>
|
|
{/if}
|
|
|
|
</div>
|
|
|
|
<div class="col-md-4 col-12 mt-md-0 mt-3">
|
|
<EmpireStats stats={stats.empires} />
|
|
</div>
|
|
|
|
</div>
|
|
{/if}
|
|
|