Browse Source

feat: add HN feature

master
Muthu Kumar 2 days ago
parent
commit
d9e8364387
Failed to extract signature
  1. 61
      src/pages/main/Home.tsx

61
src/pages/main/Home.tsx

@ -1,12 +1,10 @@
import React, { useContext } from "react"; import React, { useContext } from "react";
import FlickerList, { Tooltip } from "../../components/FlickerList.tsx"; import FlickerList, { Tooltip } from "../../components/FlickerList.tsx";
import { ReactComponent as Arrow } from "../../assets/arrow-thin.svg"; import { css, cx } from "@emotion/css";
import { css } from "@emotion/css";
import { setupCursorTracking } from "../../util/index.ts";
import { Emoji } from "../../components/Emoji.tsx"; import { Emoji } from "../../components/Emoji.tsx";
import { AnimateEntry } from "../../components/AnimateEntry.tsx"; import { AnimateEntry } from "../../components/AnimateEntry.tsx";
import { AppContext } from "../../AppContext.ts"; import { AppContext } from "../../AppContext.ts";
import { Button } from "../../components/ButtonOrAnchor.tsx"; import { Anchor, Button } from "../../components/ButtonOrAnchor.tsx";
const Home: React.FC = () => { const Home: React.FC = () => {
const context = useContext(AppContext); const context = useContext(AppContext);
@ -69,6 +67,37 @@ const Home: React.FC = () => {
]} ]}
/> />
</section> </section>
<article
className={css`
/* Makes it look visually consistently spaced, even though it's correctly spaced by gap already */
margin-top: -0.8rem;
display: flex;
flex-wrap: wrap;
white-space: nowrap;
gap: 0.5rem;
background: #ff6600;
padding: 0.5rem 1rem;
width: fit-content;
color: #fff;
font-weight: 700;
& a {
color: #fff;
font-weight: 500;
&:hover {
color: #fff;
text-decoration: underline;
}
}
`}>
<p>We made it to HackerNews!</p>
<Emoji emoji="tada" />
<Anchor href="https://news.ycombinator.com/item?id=44778898">
[comments]
</Anchor>
<Anchor href="https://comptime.js.org">[project]</Anchor>
</article>
<main <main
className={css` className={css`
/* fiddle */ /* fiddle */
@ -101,6 +130,12 @@ const Home: React.FC = () => {
margin-top: -0.4rem; margin-top: -0.4rem;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 1rem;
`}>
<div
className={css`
display: flex;
flex-direction: column;
gap: 0.2rem; gap: 0.2rem;
`}> `}>
<p> <p>
@ -108,8 +143,8 @@ const Home: React.FC = () => {
<Tooltip <Tooltip
description={ description={
<> <>
For legal reasons, my name is <i>Anu Rahul Nandhan</i>, but I For legal reasons, my name is <i>Anu Rahul Nandhan</i>, but
generally go by my{" "} I generally go by my{" "}
<a <a
href="https://en.wiktionary.org/wiki/nom_de_guerre" href="https://en.wiktionary.org/wiki/nom_de_guerre"
target="_blank" target="_blank"
@ -126,7 +161,8 @@ const Home: React.FC = () => {
I'm from Chennai, South India I'm from Chennai, South India
<Emoji emoji="ind" /> <Emoji emoji="ind" />
</p> </p>
<p> </div>
{/* <p>
I'm looking for work! I'm looking for work!
<Emoji emoji="tada" baseline /> <Emoji emoji="tada" baseline />
</p> </p>
@ -166,13 +202,18 @@ const Home: React.FC = () => {
<Arrow /> <Arrow />
</a> </a>
</Button> </Button>
</div> */}
<Button <Button
styled="anchor" className={cx(
className="contact-button" "contact-button",
css`
width: fit-content;
font-weight: 700;
`,
)}
onClick={() => context.contact.set(true)}> onClick={() => context.contact.set(true)}>
Let's talk! Let's talk!
</Button> </Button>
</div>
</article> </article>
</main> </main>
</AnimateEntry> </AnimateEntry>

Loading…
Cancel
Save