import Link from 'next/link' import styled, { DefaultTheme } from 'styled-components' import { CustomLink } from '../../interfaces/LinkTypes'; // needed for Online Status checks // TODO: migrate to shared Status type for Games and Services interface OnlinePropType { status: string; } // replaces .title export const PageTitle = styled.h1` margin: 0; line-height: 1.15; font-size: 4rem; text-align: center; ` // replaces .description export const PageDescription = styled.p` margin: 4rem 0; line-height: 1.5; font-size: 1.5rem; text-align: center; ` // replaces .grid export const PageContentBox = styled.div` display: flex; align-items: center; justify-content: center; flex-wrap: wrap; max-width: 80%; ` // replaces .card & .contentcard export const PageCard = styled.div` margin: 1rem; padding: 1rem; text-align: center; color: ${({ theme }) => theme.colors.primary}; text-decoration: none; border: 1px solid; border-radius: 10px; border-color: ${({ theme }) => theme.colors.primary}; transition: color 0.15s ease, border-color 0.15s ease; max-width: 300px; h2 { margin: 0 0 1rem 0; font-size: 1.5rem; } p { margin: 0; font-size: 1.25rem; line-height: 1.5; } &:focus,:active,:hover { color: ${({ theme }) => theme.colors.secondary}; border-color: ${({ theme }) => theme.colors.secondary}; } ` const OnlineStatus = styled.p` color: ${props => { let ret; switch (props.status) { case "Online": ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.online; break; case "Loading": ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.loading; break; case "Offline": ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.offline; break; default: ret = ({ theme }: { theme: DefaultTheme }) => theme.colors.offline; } return ret; }}; ` // Card Content Component for Games Page export const PageCardContentGame = ({ content }: { content: CustomLink }) => { return ( <>

{content.name}

{content.desc}

{content.ip}

{content.status} ) } // Card Content Component for Services Page