PSFPortal/app/views/Profile.svelte
2024-12-20 19:15:48 -05:00

107 lines
2.6 KiB
Svelte

<script>
import { onMount } from 'svelte';
import { userId, isAdmin } from '../UserState'
import axios from 'axios'
import page from 'page'
import moment from 'moment'
import CharacterLink from '../components/CharacterLink'
import LoginList from '../components/LoginList'
import AccountLink from '../components/AccountLink'
import ActionButtons from '../components/ActionButtons'
import PermissionButtons from '../components/PermissionButtons'
import ActionModal from '../components/ActionModal.svelte'
import RoleModal from '../components/RoleModal.svelte'
export let pageCtx;
export let appAlert;
export let params;
export let ready;
ready = false;
let username;
let characters = [];
let createDate;
let email;
let account;
async function refresh() {
let loadID = params.id || $userId;
try {
const resp = await axios.get("/api/user/"+loadID+"/profile")
account = resp.data;
username = resp.data.name;
characters = resp.data.characters;
createDate = moment(resp.data.account_created).format('MMMM Do YYYY, h:mm:ss a')
+ " (" + moment(resp.data.account_created).fromNow() + ")";
email = resp.data.email;
ready = true
} catch (e) {
if (e.response && e.response.status == 403) {
if (e.response.data.message == "session required") {
page("/login?redirect="+pageCtx.pathname)
} else {
appAlert.message(e.response.data.message)
}
} else {
appAlert.message(e.message)
}
}
}
onMount(async () => {
await refresh();
});
</script>
<svelte:head>
<title>PSForever - Profile</title>
</svelte:head>
{#if account}
<h1>Account: <AccountLink account={account}/></h1>
{#if $isAdmin}
<ActionButtons {account} />
{/if}
<form>
<div class="form-group row">
<label for="staticEmail" class="col-sm-2 col-form-label">Email</label>
<div class="col-sm-10">
<input type="text" readonly class="form-control-plaintext" id="staticEmail" bind:value={email}>
</div>
</div>
<div class="form-group row">
<label for="staticAccountCreated" class="col-sm-2 col-form-label">Account Created</label>
<div class="col-sm-10">
<input type="text" readonly class="form-control-plaintext" id="staticAccountCreated" bind:value={createDate}>
</div>
</div>
</form>
<h2>Characters</h2>
<p>
{#if characters.length >= 1}
<div class="row">
{#each characters as char, i}
<div class="col-md-4 col-12">{char.name} <PermissionButtons avatar={char} /></div>
{/each}
</div>
{:else}
You have no characters
{/if}
</p>
<h2>Logins</h2>
<p>
<LoginList account_id={account.id} />
</p>
{/if}
<ActionModal on:action={() => refresh()} />
<RoleModal on:action={() => refresh()} />