-
-## Features
-
-This repository is 🔋 battery packed with:
-
-- ⚡️ Next.js 14 with App Router
-- ⚛️ React 18
-- ✨ TypeScript
-- 💨 Tailwind CSS 3 — Configured with CSS Variables to extend the **primary** color
-- 💎 Pre-built Components — Components that will **automatically adapt** with your brand color, [check here for the demo](https://tsnext-tw.thcl.dev/components)
-- 🃏 Jest — Configured for unit testing
-- 📈 Absolute Import and Path Alias — Import components using `@/` prefix
-- 📏 ESLint — Find and fix problems in your code, also will **auto sort** your imports
-- 💖 Prettier — Format your code consistently
-- 🐶 Husky & Lint Staged — Run scripts on your staged files before they are committed
-- 🤖 Conventional Commit Lint — Make sure you & your teammates follow conventional commit
-- ⏰ Release Please — Generate your changelog by activating the `release-please` workflow
-- 👷 Github Actions — Lint your code on PR
-- 🚘 Automatic Branch and Issue Autolink — Branch will be automatically created on issue **assign**, and auto linked on PR
-- 🔥 Snippets — A collection of useful snippets
-- 👀 Open Graph Helper Function — Awesome open graph generated using [og](https://github.com/theodorusclarence/og), fork it and deploy!
-- 🗺 Site Map — Automatically generate sitemap.xml
-- 📦 Expansion Pack — Easily install common libraries, additional components, and configs.
-
-See the 👉 [feature details and changelog](https://github.com/theodorusclarence/ts-nextjs-tailwind-starter/blob/main/CHANGELOG.md) 👈 for more.
-
-You can also check all of the **details and demos** on my blog post:
-
-- [One-stop Starter to Maximize Efficiency on Next.js & Tailwind CSS Projects](https://theodorusclarence.com/blog/one-stop-starter)
-
-## Getting Started
-
-### 1. Clone this template using one of the three ways
-
-1. Use this repository as template
-
- **Disclosure:** by using this repository as a template, there will be an attribution on your repository.
-
- I'll appreciate if you do, so this template can be known by others too 😄
-
- ![Use as template](https://user-images.githubusercontent.com/55318172/129183039-1a61e68d-dd90-4548-9489-7b3ccbb35810.png)
-
-2. Using `create-next-app`
-
- ```bash
- pnpm create next-app -e https://github.com/theodorusclarence/ts-nextjs-tailwind-starter ts-pnpm
- ```
-
- If you still want to use **pages directory** (_is not actively maintained_) you can use this command
-
- ```bash
- npx create-next-app -e https://github.com/theodorusclarence/ts-nextjs-tailwind-starter/tree/pages-directory project-name
- ```
-
-3. Using `degit`
-
- ```bash
- npx degit theodorusclarence/ts-nextjs-tailwind-starter YOUR_APP_NAME
- ```
-
-4. Deploy to Vercel
-
- [![Deploy with Vercel](https://vercel.com/button)](https://vercel.com/new/git/external?repository-url=https%3A%2F%2Fgithub.com%2Ftheodorusclarence%2Fts-nextjs-tailwind-starter)
-
-### 2. Install dependencies
-
-It is encouraged to use **pnpm** so the husky hooks can work properly.
+### 1. Install dependencies
```bash
pnpm install
```
-### 3. Run the development server
+### 2. Run the development server
You can start the server using this command:
@@ -90,44 +14,6 @@ You can start the server using this command:
pnpm dev
```
-Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. You can start editing the page by modifying `src/pages/index.tsx`.
-
-### 4. Change defaults
-
-There are some things you need to change including title, urls, favicons, etc.
-
-Find all comments with !STARTERCONF, then follow the guide.
-
-Don't forget to change the package name in package.json
-
-### 5. Commit Message Convention
-
-This starter is using [conventional commits](https://www.conventionalcommits.org/en/v1.0.0/), it is mandatory to use it to commit changes.
-
-## Projects using ts-nextjs-tailwind-starter
-
-
-
-- [theodorusclarence.com](https://theodorusclarence.com) ([Source](https://github.com/theodorusclarence/theodorusclarence.com))
-- [Notiolink](https://notiolink.thcl.dev/) ([Source](https://github.com/theodorusclarence/notiolink))
-- [NextJs + Materia UI + Typescript](https://github.com/AlexStack/nextjs-materia-mui-typescript-hook-form-scaffold-boilerplate-starter)
-
-Are you using this starter? Please add your page (and repo) to the end of the list via a [Pull Request](https://github.com/theodorusclarence/ts-nextjs-tailwind-starter/edit/main/README.md). 😃
-
-## Expansion Pack 📦
-
-This starter is now equipped with an [expansion pack](https://github.com/theodorusclarence/expansion-pack).
-
-You can easily add expansion such as React Hook Form + Components, Storybook, and more just using a single command line.
-
-
-
-Check out the [expansion pack repository](https://github.com/theodorusclarence/expansion-pack) for the commands
-
-### App Router Update
+### 3. Dev server
-Due to App Router update, the expansion pack is currently **outdated**. It will be updated in the future. You can still use them by copy and pasting the files.
+Open [http://localhost:3000](http://localhost:3000)
diff --git a/src/app/components/Footer.tsx b/src/app/components/Footer.tsx
new file mode 100644
index 0000000..55f4a1e
--- /dev/null
+++ b/src/app/components/Footer.tsx
@@ -0,0 +1,14 @@
+import UnderlineLink from '@/components/links/UnderlineLink';
+
+export default function Footer() {
+ return (
+
+ );
+}
diff --git a/src/app/components/Header.tsx b/src/app/components/Header.tsx
new file mode 100644
index 0000000..5514704
--- /dev/null
+++ b/src/app/components/Header.tsx
@@ -0,0 +1,10 @@
+import Logo from '~/svg/Logo.svg';
+
+export default function Header() {
+ return (
+
+
+
Next.js + Tailwind CSS + TypeScript Starter
+
+ );
+}
diff --git a/src/app/layout.tsx b/src/app/layout.tsx
index f1184cf..4f03205 100644
--- a/src/app/layout.tsx
+++ b/src/app/layout.tsx
@@ -5,6 +5,8 @@ import '@/styles/globals.css';
// !STARTERCONF This is for demo purposes, remove @/styles/colors.css import immediately
import '@/styles/colors.css';
+import Footer from '@/app/components/Footer';
+import Header from '@/app/components/Header';
import { siteConfig } from '@/constant/config';
// !STARTERCONF Change these default meta
@@ -56,7 +58,13 @@ export default function RootLayout({
}) {
return (
- {children}
+
+
+
+ {children}
+
+
+
);
}
diff --git a/src/app/page.tsx b/src/app/page.tsx
index cf0ed16..86bcdf7 100644
--- a/src/app/page.tsx
+++ b/src/app/page.tsx
@@ -1,14 +1,8 @@
'use client';
-import Head from 'next/head';
import * as React from 'react';
import '@/lib/env';
-import ArrowLink from '@/components/links/ArrowLink';
-import ButtonLink from '@/components/links/ButtonLink';
-import UnderlineLink from '@/components/links/UnderlineLink';
-import UnstyledLink from '@/components/links/UnstyledLink';
-
/**
* SVGR Support
* Caveat: No React Props Type.
@@ -16,57 +10,11 @@ import UnstyledLink from '@/components/links/UnstyledLink';
* You can override the next-env if the type is important to you
* @see https://stackoverflow.com/questions/68103844/how-to-override-next-js-svg-module-declaration
*/
-import Logo from '~/svg/Logo.svg';
// !STARTERCONF -> Select !STARTERCONF and CMD + SHIFT + F
// Before you begin editing, follow all comments with `STARTERCONF`,
// to customize the default configuration.
export default function HomePage() {
- return (
-
-
- Hi
-
-
-
-
-
Next.js + Tailwind CSS + TypeScript Starter
-
- A starter for Next.js, Tailwind CSS, and TypeScript with Absolute
- Import, Seo, Link component, pre-configured with Husky{' '}
-
-
-
- See the repository
-
-
-
-
- See all components
-
-
-
- {/* eslint-disable-next-line @next/next/no-img-element */}
-
-
-
-
-