Skip to content

Commit 6452c87

Browse files
committed
Buttons, Form, Typography ✅
1 parent f123beb commit 6452c87

File tree

19 files changed

+178
-154
lines changed

19 files changed

+178
-154
lines changed

app/favicon.ico

-25.3 KB
Binary file not shown.

app/global.css

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
@tailwind base;
2+
@tailwind components;
3+
@tailwind utilities;

app/globals.css

Lines changed: 0 additions & 33 deletions
This file was deleted.

app/layout.tsx

Lines changed: 23 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -1,22 +1,32 @@
1-
import type { Metadata } from "next";
2-
import { Inter } from "next/font/google";
3-
import "./globals.css";
1+
import "./global.css"
2+
import { Archivo_Black, Share_Tech, Share_Tech_Mono } from "next/font/google";
43

5-
const inter = Inter({ subsets: ["latin"] });
4+
const archivoBlack = Archivo_Black({
5+
subsets: ["latin"],
6+
weight: "400",
7+
variable: '--font-head',
8+
});
69

7-
export const metadata: Metadata = {
8-
title: "Create Next App",
9-
description: "Generated by create next app",
10-
};
10+
const shareTech = Share_Tech({
11+
subsets: ["latin"],
12+
weight: "400",
13+
variable: '--font-sans',
14+
});
15+
16+
const shareTechMono = Share_Tech_Mono({
17+
subsets: ["latin"],
18+
weight: "400",
19+
variable: '--font-mono',
20+
});
1121

1222
export default function RootLayout({
1323
children,
14-
}: Readonly<{
15-
children: React.ReactNode;
16-
}>) {
24+
}: {
25+
children: React.ReactNode
26+
}) {
1727
return (
1828
<html lang="en">
19-
<body className={inter.className}>{children}</body>
29+
<body className={`${shareTech.className} ${archivoBlack.variable} ${shareTech.variable} ${shareTechMono.variable}`}>{children}</body>
2030
</html>
21-
);
31+
)
2232
}

app/page.tsx

Lines changed: 32 additions & 104 deletions
Original file line numberDiff line numberDiff line change
@@ -1,113 +1,41 @@
1-
import Image from "next/image";
1+
import React from "react";
2+
import { Button, H1, H2, H3, H4, H5, H6, Input, Textarea } from "@/components";
23

3-
export default function Home() {
4+
export default function page() {
45
return (
5-
<main className="flex min-h-screen flex-col items-center justify-between p-24">
6-
<div className="z-10 w-full max-w-5xl items-center justify-between font-mono text-sm lg:flex">
7-
<p className="fixed left-0 top-0 flex w-full justify-center border-b border-gray-300 bg-gradient-to-b from-zinc-200 pb-6 pt-8 backdrop-blur-2xl dark:border-neutral-800 dark:bg-zinc-800/30 dark:from-inherit lg:static lg:w-auto lg:rounded-xl lg:border lg:bg-gray-200 lg:p-4 lg:dark:bg-zinc-800/30">
8-
Get started by editing&nbsp;
9-
<code className="font-mono font-bold">app/page.tsx</code>
10-
</p>
11-
<div className="fixed bottom-0 left-0 flex h-48 w-full items-end justify-center bg-gradient-to-t from-white via-white dark:from-black dark:via-black lg:static lg:size-auto lg:bg-none">
12-
<a
13-
className="pointer-events-none flex place-items-center gap-2 p-8 lg:pointer-events-auto lg:p-0"
14-
href="https://vercel.com?utm_source=create-next-app&utm_medium=appdir-template&utm_campaign=create-next-app"
15-
target="_blank"
16-
rel="noopener noreferrer"
17-
>
18-
By{" "}
19-
<Image
20-
src="/vercel.svg"
21-
alt="Vercel Logo"
22-
className="dark:invert"
23-
width={100}
24-
height={24}
25-
priority
26-
/>
27-
</a>
28-
</div>
29-
</div>
30-
31-
<div className="relative z-[-1] flex place-items-center before:absolute before:h-[300px] before:w-full before:-translate-x-1/2 before:rounded-full before:bg-gradient-radial before:from-white before:to-transparent before:blur-2xl before:content-[''] after:absolute after:-z-20 after:h-[180px] after:w-full after:translate-x-1/3 after:bg-gradient-conic after:from-sky-200 after:via-blue-200 after:blur-2xl after:content-[''] before:dark:bg-gradient-to-br before:dark:from-transparent before:dark:to-blue-700 before:dark:opacity-10 after:dark:from-sky-900 after:dark:via-[#0141ff] after:dark:opacity-40 sm:before:w-[480px] sm:after:w-[240px] before:lg:h-[360px]">
32-
<Image
33-
className="relative dark:drop-shadow-[0_0_0.3rem_#ffffff70] dark:invert"
34-
src="/next.svg"
35-
alt="Next.js Logo"
36-
width={180}
37-
height={37}
38-
priority
39-
/>
40-
</div>
6+
<div className="container max-w-6xl mx-auto">
7+
<H1>Welcome to RetroUI</H1>
418

42-
<div className="mb-32 grid text-center lg:mb-0 lg:w-full lg:max-w-5xl lg:grid-cols-4 lg:text-left">
43-
<a
44-
href="https://nextjs.org/docs?utm_source=create-next-app&utm_medium=appdir-template&utm_campaign=create-next-app"
45-
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
46-
target="_blank"
47-
rel="noopener noreferrer"
48-
>
49-
<h2 className="mb-3 text-2xl font-semibold">
50-
Docs{" "}
51-
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
52-
-&gt;
53-
</span>
54-
</h2>
55-
<p className="m-0 max-w-[30ch] text-sm opacity-50">
56-
Find in-depth information about Next.js features and API.
57-
</p>
58-
</a>
9+
<div className="space-y-8 mt-12">
10+
<div>
11+
<H3>Typography</H3>
5912

60-
<a
61-
href="https://nextjs.org/learn?utm_source=create-next-app&utm_medium=appdir-template-tw&utm_campaign=create-next-app"
62-
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
63-
target="_blank"
64-
rel="noopener noreferrer"
65-
>
66-
<h2 className="mb-3 text-2xl font-semibold">
67-
Learn{" "}
68-
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
69-
-&gt;
70-
</span>
71-
</h2>
72-
<p className="m-0 max-w-[30ch] text-sm opacity-50">
73-
Learn about Next.js in an interactive course with&nbsp;quizzes!
74-
</p>
75-
</a>
13+
<H1>This is H1</H1>
14+
<H2>This is H2</H2>
15+
<H3>This is H3</H3>
16+
<H4>This is H4</H4>
17+
<H5>This is H5</H5>
18+
<H6>This is H6</H6>
19+
</div>
20+
<div>
21+
<H3>Buttons</H3>
22+
<Button>Primary Button</Button>
23+
</div>
7624

77-
<a
78-
href="https://vercel.com/templates?framework=next.js&utm_source=create-next-app&utm_medium=appdir-template&utm_campaign=create-next-app"
79-
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
80-
target="_blank"
81-
rel="noopener noreferrer"
82-
>
83-
<h2 className="mb-3 text-2xl font-semibold">
84-
Templates{" "}
85-
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
86-
-&gt;
87-
</span>
88-
</h2>
89-
<p className="m-0 max-w-[30ch] text-sm opacity-50">
90-
Explore starter templates for Next.js.
91-
</p>
92-
</a>
25+
<div>
26+
<H3>Forms</H3>
27+
<Input />
28+
<div className="h-4"></div>
29+
<Textarea />
30+
</div>
9331

94-
<a
95-
href="https://vercel.com/new?utm_source=create-next-app&utm_medium=appdir-template&utm_campaign=create-next-app"
96-
className="group rounded-lg border border-transparent px-5 py-4 transition-colors hover:border-gray-300 hover:bg-gray-100 hover:dark:border-neutral-700 hover:dark:bg-neutral-800/30"
97-
target="_blank"
98-
rel="noopener noreferrer"
99-
>
100-
<h2 className="mb-3 text-2xl font-semibold">
101-
Deploy{" "}
102-
<span className="inline-block transition-transform group-hover:translate-x-1 motion-reduce:transform-none">
103-
-&gt;
104-
</span>
105-
</h2>
106-
<p className="m-0 max-w-[30ch] text-balance text-sm opacity-50">
107-
Instantly deploy your Next.js site to a shareable URL with Vercel.
108-
</p>
109-
</a>
32+
<div>
33+
<H3>Forms</H3>
34+
<Input />
35+
<div className="h-4"></div>
36+
<Textarea />
37+
</div>
11038
</div>
111-
</main>
39+
</div>
11240
);
11341
}

components/Buttons/Button.tsx

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
import React, { ReactNode } from 'react';
2+
3+
interface ButtonProps {
4+
children: ReactNode;
5+
size?: 'sm' | 'md' | 'lg';
6+
}
7+
8+
export function Button({ children, size = 'md' }: ButtonProps) {
9+
const sizeClasses = {
10+
sm: 'px-4 py-1 text-sm',
11+
md: 'px-6 py-2 text-md',
12+
lg: 'px-8 py-3 text-lg',
13+
};
14+
15+
return (
16+
<button
17+
className={`font-head bg-primary-400 border-2 border-black shadow-md hover:shadow-xs transition-all ${sizeClasses[size]}`}
18+
>
19+
{children}
20+
</button>
21+
);
22+
}

components/Buttons/index.tsx

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
export * from "./Button"

components/Form/Input.tsx

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
import React from "react";
2+
3+
export function Input({
4+
type = "text",
5+
placeholder = "Enter text",
6+
className = "",
7+
...props
8+
}) {
9+
return (
10+
<input
11+
type={type}
12+
placeholder={placeholder}
13+
className={`px-4 py-2 w-full border-2 border-black shadow-md transition focus:outline-none focus:shadow-xs ${className}`}
14+
{...props}
15+
/>
16+
);
17+
}

components/Form/Textarea.tsx

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
import React from "react";
2+
3+
export function Textarea({
4+
type = "text",
5+
placeholder = "Enter text...",
6+
className = "",
7+
...props
8+
}) {
9+
return (
10+
<textarea
11+
placeholder={placeholder}
12+
rows={4}
13+
className={`px-4 py-2 w-full border-2 border-black shadow-md transition focus:outline-none focus:shadow-xs ${className}`}
14+
{...props}
15+
/>
16+
);
17+
}

components/Form/index.tsx

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,2 @@
1+
export * from "./Input"
2+
export * from "./Textarea"

0 commit comments

Comments
 (0)