parent
da5ec4b599
commit
1de19d7587
@ -1,194 +0,0 @@ |
||||
import type { NextPageWithLayout } from "./_app"; |
||||
import type { ReactElement } from "react"; |
||||
import Layout from "../components/layout"; |
||||
import styled from "styled-components"; |
||||
import IconLink from "components/iconlink"; |
||||
import ScrollMe from "components/scrollme"; |
||||
import { faEnvelope } from "@fortawesome/free-solid-svg-icons"; |
||||
import { faGit, faGithub } from "@fortawesome/free-brands-svg-icons"; |
||||
|
||||
export const Section = styled.section` |
||||
display: flex; |
||||
justify-content: center; |
||||
flex-direction: column; |
||||
padding: 0 1rem; |
||||
/*margin: 2rem 0;*/ |
||||
margin: 0 0; |
||||
min-height: 100vh; |
||||
|
||||
h2, |
||||
h3 { |
||||
font-size: 2rem; |
||||
margin: 8px 0; |
||||
} |
||||
|
||||
p { |
||||
margin: 0; |
||||
color: var(--fg); |
||||
} |
||||
|
||||
.topmargin { |
||||
margin-top: 1rem; |
||||
} |
||||
|
||||
ul li { |
||||
margin: 0.5rem 2.5rem; |
||||
} |
||||
|
||||
#img-container { |
||||
display: flex; |
||||
justify-content: center; |
||||
} |
||||
#img-container img { |
||||
width: 22rem; |
||||
height: auto; |
||||
} |
||||
|
||||
footer { |
||||
margin-top: 1rem; |
||||
opacity: 0.5; |
||||
} |
||||
`; |
||||
|
||||
export const Code = styled.code` |
||||
font-family: monospace; |
||||
font-size: 0.9rem; |
||||
background-color: var(--bg-emph); |
||||
color: var(--fg-code); |
||||
border-radius: 0.4rem; |
||||
padding: 0.1rem 0.4rem; |
||||
`; |
||||
|
||||
export const CList = styled.ul` |
||||
list-style: none; |
||||
|
||||
li { |
||||
margin: 1rem !important; |
||||
} |
||||
`; |
||||
|
||||
export const Nem = styled.span` |
||||
color: var(--fg-faded); |
||||
`; |
||||
|
||||
export const LinkList = styled.div` |
||||
display: flex; |
||||
gap: 1.5rem; |
||||
font-size: 1.2rem; |
||||
border: unset; |
||||
justify-content: center; |
||||
|
||||
a { |
||||
color: var(--fg-button); |
||||
transition: var(--trans-time) opacity; |
||||
} |
||||
|
||||
a:hover { |
||||
opacity: 0.4; |
||||
} |
||||
|
||||
@media screen and (max-width: 960px) { |
||||
word-break: break-word; |
||||
} |
||||
`; |
||||
|
||||
function getAge() { |
||||
let birth = 1050019200; |
||||
let now = Math.floor(Date.now() / 1000); |
||||
return now - birth; |
||||
} |
||||
|
||||
function secondsToYears(secs: number) { |
||||
return Math.floor(secs / 31557600.0); |
||||
} |
||||
|
||||
const Page: NextPageWithLayout = () => { |
||||
return ( |
||||
<> |
||||
<Section> |
||||
<h2 id="about">/almqv</h2> |
||||
<p> |
||||
I am a {secondsToYears(getAge())} year old{" "} |
||||
<em>Computer Science & Engineering student</em> with a passion for{" "} |
||||
<em>physics</em>, <em>programming</em>, <em>mathematics</em> and |
||||
anything <em>*NIX</em> <Nem>(Linux, UNIX etc)</Nem> related. |
||||
</p> |
||||
{/*TODO: Add GitHub code frequency/contrib here*/} |
||||
<p className="topmargin"> |
||||
Most of my projects are open-source, and if you are interested, you |
||||
can find all of my projects on my <a href="https://git.wych.dev/elal" target="_blank" rel="noreferrer">git-server</a> or <a href="https://github.com/almqv" target="_blank" rel="GITHUBuuuuuuuu |
||||
</Auuuu> |
||||
. |
||||
</p> |
||||
|
||||
<LinkList className="topmargin"> |
||||
<IconLink |
||||
href="#contact" |
||||
icon={faEnvelope} |
||||
target="_self" |
||||
rel="noreferrer" |
||||
/> |
||||
{/*<IconLink href="/projects" icon={ faFolderOpen } target="_self" rel="noreferrer"/>*/} |
||||
<IconLink |
||||
href="https://github.com/almqv" |
||||
icon={faGithub} |
||||
target="_blank" |
||||
rel="noreferrer" |
||||
/> |
||||
<IconLink |
||||
href="https://git.wych.dev/elal" |
||||
icon={faGit} |
||||
target="_blank" |
||||
rel="noreferrer" |
||||
/> |
||||
</LinkList> |
||||
|
||||
<ScrollMe href="#contact" /> |
||||
</Section> |
||||
|
||||
<Section> |
||||
<h2 id="contact">Contact</h2> |
||||
<p> |
||||
You can contact me through email. And if you prefer it, you can |
||||
contact me using PGP. Do note that my{" "} |
||||
<em>email address below is encrypted</em> as a precaution against bots |
||||
et cetera. <em>Do not worry, it is easy to crack</em>. Alternatively |
||||
you could query for my email with my PGP fingerprint (key-id) on some |
||||
PGP key server (i.e. the{" "} |
||||
<a href="https://pgp.mit.edu/" target="_blank" rel="noreferrer"> |
||||
MIT |
||||
</a>{" "} |
||||
or{" "} |
||||
<a |
||||
href="https://keyserver.ubuntu.com/" |
||||
target="_blank" |
||||
rel="noreferrer" |
||||
> |
||||
Ubuntu |
||||
</a>{" "} |
||||
key-server). |
||||
</p> |
||||
<CList> |
||||
<li> |
||||
PGP fingerprint:{" "} |
||||
<Code>68B2 9768 49F0 3C72 38AE B081 E31A 99CE 3E75 A158</Code> |
||||
</li> |
||||
<li> |
||||
Email: <Code>cnlueXpkaXZmZ0B0em52eS5wYnoK</Code> |
||||
</li> |
||||
<li> |
||||
GitHub:{" "} |
||||
<a href="https://github.com/almqv" target="_blank" rel="noreferrer"> |
||||
github.com/almqv |
||||
</a> |
||||
</li> |
||||
</CList> |
||||
</Section> |
||||
</> |
||||
); |
||||
}; |
||||
|
||||
Page.getLayout = (page: ReactElement) => { |
||||
return <Layout>{page}</Layout>; |
||||
}; |
||||
export default Page; |
Loading…
Reference in new issue