diff --git a/test-nextjs/.gitignore b/test-nextjs/.gitignore new file mode 100644 index 0000000000..706572b1d2 --- /dev/null +++ b/test-nextjs/.gitignore @@ -0,0 +1,43 @@ +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.* +.yarn/* +!.yarn/patches +!.yarn/plugins +!.yarn/releases +!.yarn/versions + +# testing +/coverage + +# next.js +/.next/ +/out/ + +# production +/build + +# misc +.DS_Store +*.pem + +# debug +npm-debug.log* +yarn-debug.log* +yarn-error.log* +.pnpm-debug.log* + +# env files (can opt-in for committing if needed) +.env* + +# vercel +.vercel + +# typescript +*.tsbuildinfo +next-env.d.ts + +/app/types/generated \ No newline at end of file diff --git a/test-nextjs/README.md b/test-nextjs/README.md new file mode 100644 index 0000000000..e215bc4ccf --- /dev/null +++ b/test-nextjs/README.md @@ -0,0 +1,36 @@ +This is a [Next.js](https://nextjs.org) project bootstrapped with [`create-next-app`](https://nextjs.org/docs/app/api-reference/cli/create-next-app). + +## Getting Started + +First, run the development server: + +```bash +npm run dev +# or +yarn dev +# or +pnpm dev +# or +bun dev +``` + +Open [http://localhost:3000](http://localhost:3000) with your browser to see the result. + +You can start editing the page by modifying `app/page.tsx`. The page auto-updates as you edit the file. + +This project uses [`next/font`](https://nextjs.org/docs/app/building-your-application/optimizing/fonts) to automatically optimize and load [Geist](https://vercel.com/font), a new font family for Vercel. + +## Learn More + +To learn more about Next.js, take a look at the following resources: + +- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API. +- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial. + +You can check out [the Next.js GitHub repository](https://github.com/vercel/next.js) - your feedback and contributions are welcome! + +## Deploy on Vercel + +The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new?utm_medium=default-template&filter=next.js&utm_source=create-next-app&utm_campaign=create-next-app-readme) from the creators of Next.js. + +Check out our [Next.js deployment documentation](https://nextjs.org/docs/app/building-your-application/deploying) for more details. diff --git a/test-nextjs/app/favicon.ico b/test-nextjs/app/favicon.ico new file mode 100644 index 0000000000..718d6fea48 Binary files /dev/null and b/test-nextjs/app/favicon.ico differ diff --git a/test-nextjs/app/globals.css b/test-nextjs/app/globals.css new file mode 100644 index 0000000000..e3734be15e --- /dev/null +++ b/test-nextjs/app/globals.css @@ -0,0 +1,42 @@ +:root { + --background: #ffffff; + --foreground: #171717; +} + +@media (prefers-color-scheme: dark) { + :root { + --background: #0a0a0a; + --foreground: #ededed; + } +} + +html, +body { + max-width: 100vw; + overflow-x: hidden; +} + +body { + color: var(--foreground); + background: var(--background); + font-family: Arial, Helvetica, sans-serif; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} + +* { + box-sizing: border-box; + padding: 0; + margin: 0; +} + +a { + color: inherit; + text-decoration: none; +} + +@media (prefers-color-scheme: dark) { + html { + color-scheme: dark; + } +} diff --git a/test-nextjs/app/layout.tsx b/test-nextjs/app/layout.tsx new file mode 100644 index 0000000000..42fc323e4b --- /dev/null +++ b/test-nextjs/app/layout.tsx @@ -0,0 +1,32 @@ +import type { Metadata } from "next"; +import { Geist, Geist_Mono } from "next/font/google"; +import "./globals.css"; + +const geistSans = Geist({ + variable: "--font-geist-sans", + subsets: ["latin"], +}); + +const geistMono = Geist_Mono({ + variable: "--font-geist-mono", + subsets: ["latin"], +}); + +export const metadata: Metadata = { + title: "Create Next App", + description: "Generated by create next app", +}; + +export default function RootLayout({ + children, +}: Readonly<{ + children: React.ReactNode; +}>) { + return ( + + + {children} + + + ); +} diff --git a/test-nextjs/app/page.module.css b/test-nextjs/app/page.module.css new file mode 100644 index 0000000000..ee9b8e6339 --- /dev/null +++ b/test-nextjs/app/page.module.css @@ -0,0 +1,168 @@ +.page { + --gray-rgb: 0, 0, 0; + --gray-alpha-200: rgba(var(--gray-rgb), 0.08); + --gray-alpha-100: rgba(var(--gray-rgb), 0.05); + + --button-primary-hover: #383838; + --button-secondary-hover: #f2f2f2; + + display: grid; + grid-template-rows: 20px 1fr 20px; + align-items: center; + justify-items: center; + min-height: 100svh; + padding: 80px; + gap: 64px; + font-family: var(--font-geist-sans); +} + +@media (prefers-color-scheme: dark) { + .page { + --gray-rgb: 255, 255, 255; + --gray-alpha-200: rgba(var(--gray-rgb), 0.145); + --gray-alpha-100: rgba(var(--gray-rgb), 0.06); + + --button-primary-hover: #ccc; + --button-secondary-hover: #1a1a1a; + } +} + +.main { + display: flex; + flex-direction: column; + gap: 32px; + grid-row-start: 2; +} + +.main ol { + font-family: var(--font-geist-mono); + padding-left: 0; + margin: 0; + font-size: 14px; + line-height: 24px; + letter-spacing: -0.01em; + list-style-position: inside; +} + +.main li:not(:last-of-type) { + margin-bottom: 8px; +} + +.main code { + font-family: inherit; + background: var(--gray-alpha-100); + padding: 2px 4px; + border-radius: 4px; + font-weight: 600; +} + +.ctas { + display: flex; + gap: 16px; +} + +.ctas a { + appearance: none; + border-radius: 128px; + height: 48px; + padding: 0 20px; + border: none; + border: 1px solid transparent; + transition: + background 0.2s, + color 0.2s, + border-color 0.2s; + cursor: pointer; + display: flex; + align-items: center; + justify-content: center; + font-size: 16px; + line-height: 20px; + font-weight: 500; +} + +a.primary { + background: var(--foreground); + color: var(--background); + gap: 8px; +} + +a.secondary { + border-color: var(--gray-alpha-200); + min-width: 180px; +} + +.footer { + grid-row-start: 3; + display: flex; + gap: 24px; +} + +.footer a { + display: flex; + align-items: center; + gap: 8px; +} + +.footer img { + flex-shrink: 0; +} + +/* Enable hover only on non-touch devices */ +@media (hover: hover) and (pointer: fine) { + a.primary:hover { + background: var(--button-primary-hover); + border-color: transparent; + } + + a.secondary:hover { + background: var(--button-secondary-hover); + border-color: transparent; + } + + .footer a:hover { + text-decoration: underline; + text-underline-offset: 4px; + } +} + +@media (max-width: 600px) { + .page { + padding: 32px; + padding-bottom: 80px; + } + + .main { + align-items: center; + } + + .main ol { + text-align: center; + } + + .ctas { + flex-direction: column; + } + + .ctas a { + font-size: 14px; + height: 40px; + padding: 0 16px; + } + + a.secondary { + min-width: auto; + } + + .footer { + flex-wrap: wrap; + align-items: center; + justify-content: center; + } +} + +@media (prefers-color-scheme: dark) { + .logo { + filter: invert(); + } +} diff --git a/test-nextjs/app/page.tsx b/test-nextjs/app/page.tsx new file mode 100644 index 0000000000..7064271f26 --- /dev/null +++ b/test-nextjs/app/page.tsx @@ -0,0 +1,99 @@ +import Image from "next/image"; +import styles from "./page.module.css"; +import { validateParsePerson } from "./types/generated/person"; + +export default function Home() { + const person = validateParsePerson('{"name": "John", "age": 30}'); + console.info(person); + + return ( +
+
+ Next.js logo +
    +
  1. + Get started by editing app/page.tsx. +
  2. +
  3. Save and see your changes instantly.
  4. +
+ +
+ + Vercel logomark + Deploy now + + + Read our docs + +
+
+ +
+ ); +} diff --git a/test-nextjs/app/types/templates/person.ts b/test-nextjs/app/types/templates/person.ts new file mode 100644 index 0000000000..c5a36e8e0d --- /dev/null +++ b/test-nextjs/app/types/templates/person.ts @@ -0,0 +1,8 @@ +import typia from 'typia'; + +type Person = { + name: string; + age: number; +}; + +export const validateParsePerson = typia.json.createValidateParse(); diff --git a/test-nextjs/next.config.ts b/test-nextjs/next.config.ts new file mode 100644 index 0000000000..e9ffa3083a --- /dev/null +++ b/test-nextjs/next.config.ts @@ -0,0 +1,7 @@ +import type { NextConfig } from "next"; + +const nextConfig: NextConfig = { + /* config options here */ +}; + +export default nextConfig; diff --git a/test-nextjs/package.json b/test-nextjs/package.json new file mode 100644 index 0000000000..c7874811ca --- /dev/null +++ b/test-nextjs/package.json @@ -0,0 +1,29 @@ +{ + "name": "test-nextjs", + "version": "0.1.0", + "private": true, + "scripts": { + "dev": "next dev --turbopack", + "build": "next build", + "start": "next start", + "lint": "next lint", + "typia": "rimraf app/types/generated && typia generate --input app/types/templates --output app/types/generated --project tsconfig.json", + "prepare": "npm run typia" + }, + "dependencies": { + "next": "15.1.0", + "react": "^19.0.0", + "react-dom": "^19.0.0", + "typia": "^7.4.0" + }, + "devDependencies": { + "eslint-config-next": "15.1.0", + "eslint": "^9", + "rimraf": "^6.0.1", + "typescript": "^5", + "@eslint/eslintrc": "^3", + "@types/node": "^20", + "@types/react-dom": "^19", + "@types/react": "^19" + } +} \ No newline at end of file diff --git a/test-nextjs/public/file.svg b/test-nextjs/public/file.svg new file mode 100644 index 0000000000..004145cddf --- /dev/null +++ b/test-nextjs/public/file.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/test-nextjs/public/globe.svg b/test-nextjs/public/globe.svg new file mode 100644 index 0000000000..567f17b0d7 --- /dev/null +++ b/test-nextjs/public/globe.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/test-nextjs/public/next.svg b/test-nextjs/public/next.svg new file mode 100644 index 0000000000..5174b28c56 --- /dev/null +++ b/test-nextjs/public/next.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/test-nextjs/public/vercel.svg b/test-nextjs/public/vercel.svg new file mode 100644 index 0000000000..7705396033 --- /dev/null +++ b/test-nextjs/public/vercel.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/test-nextjs/public/window.svg b/test-nextjs/public/window.svg new file mode 100644 index 0000000000..b2b2a44f6e --- /dev/null +++ b/test-nextjs/public/window.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/test-nextjs/tsconfig.json b/test-nextjs/tsconfig.json new file mode 100644 index 0000000000..d8b93235f2 --- /dev/null +++ b/test-nextjs/tsconfig.json @@ -0,0 +1,27 @@ +{ + "compilerOptions": { + "target": "ES2017", + "lib": ["dom", "dom.iterable", "esnext"], + "allowJs": true, + "skipLibCheck": true, + "strict": true, + "noEmit": true, + "esModuleInterop": true, + "module": "esnext", + "moduleResolution": "bundler", + "resolveJsonModule": true, + "isolatedModules": true, + "jsx": "preserve", + "incremental": true, + "plugins": [ + { + "name": "next" + } + ], + "paths": { + "@/*": ["./*"] + } + }, + "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"], + "exclude": ["node_modules"] +}