import { ReactNode, Children, useState, useEffect, useContext } from 'react';
import Icon from '@mdi/react';
import axios from 'axios';
import { NavBar } from '../components/navbar';
import { CenteredPage, PageTitle } from '../components/page';
import { Vierkant, IconLabelButton } from '../components/ui';
import { AccountAvatar } from '../components/account';
import { userInfo, userGames } from '../api/api';
import RecentGames from '../components/recentGames';
import { ToastContext } from '../components/toast';
import { SocketContext } from '../components/socketContext';
import { Footer } from '../components/footer';
import PersonAddOutlinedIcon from '@material-ui/icons/PersonAddOutlined';
import AssignmentIndOutlinedIcon from '@material-ui/icons/AssignmentIndOutlined';
import ArrowDownwardOutlinedIcon from '@material-ui/icons/ArrowDownwardOutlined';
import ArrowUpwardOutlinedIcon from '@material-ui/icons/ArrowUpwardOutlined';
import PeopleOutlineOutlinedIcon from '@material-ui/icons/PeopleOutlineOutlined';
import EditOutlinedIcon from '@material-ui/icons/EditOutlined';
import SettingsOutlinedIcon from '@material-ui/icons/SettingsOutlined';
import DoneOutlinedIcon from '@material-ui/icons/DoneOutlined';
import {
mdiAccountCancelOutline,
mdiEqual,
mdiCheckboxBlankCircle,
mdiClipboardTextOutline,
mdiGamepadSquareOutline,
mdiEarth,
mdiAccountMinusOutline,
mdiAccountRemoveOutline } from '@mdi/js';
function InfoModule(props: {
label: string;
icon: ReactNode;
}) {
return
{props.icon}
{props.label}
}
function InfoSection(props: { children: ReactNode }) {
return
{props.children}
}
export default function AccountPage() {
var server = typeof window === "undefined";
var loggedIn = !server && document.cookie.includes("token");
var pageID = server ? "" : new URLSearchParams(window.location.search).get("id");
if (!loggedIn && !pageID) !server && window.history.go(-1);
var reqData = loggedIn && pageID ? { "id": pageID } : undefined;
var [user, setUser] = useState();
var [gameInfo, setGameInfo] = useState();
var [editingStatus, setEditingStatus] = useState(false);
var [relation, setRelation] = useState("none");
var [ownPage, setOwnPage] = useState(loggedIn && !pageID);
var { toast } = useContext(ToastContext);
var { io } = useContext(SocketContext);
async function getUserData(): Promise {
var userReq = await axios.request({
method: "post",
url: `/api/user/info`,
headers: {"content-type": "application/json"},
data: reqData
});
setUser(userReq.data);
return userReq.data
}
async function getRelationTo(user: userInfo) {
var user = await getUserData();
setRelation(user.relation || "none");
}
function setIOListeners(user: userInfo) {
io.on("changedRelation", (data: { id: string }) => {
if (data.id != user.id) return;
getRelationTo(user);
});
io.on("incomingFriendRequest", getRelationTo);
}
useEffect(() => {(async() => {
var user = await getUserData();
getRelationTo(user);
setIOListeners(user);
})()}, []);
useEffect(() => {(async() => {
var userReq = await axios.request({
method: "post",
url: `/api/user/info`,
headers: {"content-type": "application/json"}
});
setOwnPage(ownPage || userReq.data.id == pageID);
})()}, []);
// Get recent games
useEffect(() => {(async() => {
var userGamesReq = await axios.request({
method: "post",
url: `/api/user/games`,
headers: {"content-type": "application/json"},
data: reqData
});
setGameInfo(userGamesReq.data);
})()}, []);
return
Profiel
{user?.username}
{user?.status}
{ loggedIn &&
{
ownPage ?
} href="/settings" text="Instellingen"/>
{
!editingStatus ?
}
text="Status bewerken"
onclick={() => setEditingStatus(true)}/> :
}
text="Status opslaan"
onclick={() => {
setEditingStatus(false)
axios.request({
method: "post",
url: `/api/user/status`,
headers: {"content-type": "application/json"},
data: { "status": document.getElementById("status").innerText }
});
}}/>
}
:
{(() => {
var icon = {
"blocked":
}[relation] ||
var text = {
"blocked": "Deblokkeren"
}[relation] || "Blokkeren"
return {
var nextRelation = {
"blocked": {
"endpoint": "/api/social/unblock",
"action": `${user.username} gedeblokkeerd`,
"relation": "none",
"icon": ,
}
}[relation] || {
"endpoint": "/api/social/block",
"action": `${user.username} geblokkeerd`,
"relation": "blocked",
"icon": ,
}
axios.request({
method: "post",
url: nextRelation.endpoint,
headers: {"content-type": "application/json"},
data: { "id": user?.id }
})
.then(() => {
toast({ message: nextRelation.action,
type: "confirmation",
icon: nextRelation.icon });
setRelation(nextRelation.relation);
});
}}/>
})()}
{(() => {
var icon = {
"friends": ,
"outgoing": ,
"incoming":
}[relation] ||
var text = {
"friends": "Vriend verwijderen",
"outgoing": "Vriendschapsverzoek annuleren",
"incoming": "Vriendschapsverzoek accepteren"
}[relation] || "Vriendschapsverzoek sturen"
return {
var nextRelation = {
"friends": {
"endpoint": "/api/social/remove",
"action": `${user.username} succesvol verwijderd als vriend`,
"relation": "none",
"icon": ,
},
"outgoing": {
"endpoint": "/api/social/remove",
"action": `Vriendschapsverzoek naar ${user.username} geannuleerd`,
"relation": "none",
"icon": ,
},
"incoming": {
"endpoint": "/api/social/accept",
"action": `Vriendschapsverzoek van ${user.username} geaccepteerd`,
"relation": "friends",
"icon": ,
},
}[relation] || {
"endpoint": "/api/social/request",
"action": `Vriendschapsverzoek gestuurd naar ${user.username}`,
"relation": "outgoing",
"icon": ,
}
axios.request({
method: "post",
url: nextRelation.endpoint,
headers: {"content-type": "application/json"},
data: { "id": user?.id }
})
.then(() => {
toast({ message: nextRelation.action,
type: "confirmation",
icon: nextRelation.icon });
setRelation(nextRelation.relation);
});
}}/>
})()}
}
}
} label="Online"/>
} label={ (() => {
var memberSince = "Lid sinds";
var registered = new Date(user?.registered);
memberSince += " " + registered.toLocaleString("nl-nl", { month: "long", day: "numeric" });
var currentYear = new Date().getFullYear();
var memberYear = registered.getFullYear();
if (currentYear != memberYear) memberSince += " " + memberYear;
return memberSince;
})() }/>
} label={(() => {
var label = user?.friends.toString() + " ";
label += user?.friends == 1 ? "vriend" : "vrienden";
return label;
})()}/>
} label="Nederland"/>
} label={ gameInfo?.totals.win + " keer gewonnen" }/>
} label={ gameInfo?.totals.draw + " keer gelijkspel" }/>
} label={ gameInfo?.totals.lose + " keer verloren" }/>
} label={ "Score: " + user?.rating }/>
} label={(() => {
var label = gameInfo?.totals.games.toString() + " ";
label += gameInfo?.totals.games == 1 ? "potje" : "potjes";
return label;
})()}/>
}