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 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);
	useEffect(() => {(async() => {
		var userReq = await axios.request({
			method: "post",
			url: `/api/user/info`,
			headers: {"content-type": "application/json"}
		});
		setOwnPage(ownPage || userReq.data.id == pageID);
	})()}, []);
	useEffect(() => {(async() => {
		var userReq = await axios.request({
			method: "post",
			url: `/api/user/info`,
			headers: {"content-type": "application/json"},
			data: reqData
		});
		setUser(userReq.data);
		setRelation(userReq.data.relation || "none");
	})()}, []);
	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(nextRelation.action,
											  "confirmation",
											  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(nextRelation.action,
											  "confirmation",
											  nextRelation.icon);
										setRelation(nextRelation.relation);
									});
								}}/>
							})()}
						
					}
}
				
 
}