Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/syhner/next-kickstart

Next.js 14 kickstarter. Zero setup & edge ready. Take what you need: ESLint, Prettier, Tailwind, tRPC, WebSockets, Drizzle, Lucia Auth, Vitest, Testing Library, Playwright, PWA, Docker, CI, Bun
https://github.com/syhner/next-kickstart

authjs boilerplate bun drizzle drizzle-orm edge edge-runtime github-actions next-auth next-starter nextjs nextjs-app-router playwright pwa tailwindcss template testing-library trpc vitest websockets

Last synced: 3 months ago
JSON representation

Next.js 14 kickstarter. Zero setup & edge ready. Take what you need: ESLint, Prettier, Tailwind, tRPC, WebSockets, Drizzle, Lucia Auth, Vitest, Testing Library, Playwright, PWA, Docker, CI, Bun

Awesome Lists containing this project

README

        

## next-kickstart

Feature packed Next.js boilerplate. Zero setup. Edge ready.

Some features depend on environment variables (indicated in features list with ๐Ÿ’ก) and so require enabling. They are disabled by default so that the app runs without any setup. They can be enabled by uncommenting all lines under where `@enable {feature}` appears.

## ๐Ÿ“š Features

**View the [repository branches](https://github.com/syhner/next-kickstart/branches) for other feature sets** (e.g. Bun)

### Core

- ๐Ÿ—๏ธ [**TypeScript**](https://www.typescriptlang.org/) - Configured to maximize type safety
- โš™๏ธ [**T3 Env**](https://github.com/t3-oss/t3-env) - Environment variable validation
- ๐ŸŒ [**tRPC**](https://trpc.io/) - Create end-to-end type-safe APIs that work in both client and server components
- โšก๐Ÿ’ก [**WebSockets**](https://pusher.com) - Real-time communication (using Pusher, but can be swapped out for alternatives)
- ๐Ÿ”— integrates with tRPC for end-to-end type-safe events
- ๐Ÿ’ฝ๐Ÿ’ก [**Drizzle**](https://orm.drizzle.team/) - ORM with maximal type safety
- ๐Ÿ”’๐Ÿ’ก [**Lucia Auth**](https://lucia-auth.com/) - Flexible and secure authentication
- ๐Ÿ”—๐Ÿ’ก integrates with Drizzle to store auth data

### Development

- ๐Ÿ“ [**ESLint**](https://eslint.org/) - Consistent code standards
- โœจ [**Prettier**](https://prettier.io/) - Consistent code styling
- ๐ŸŽจ [**Tailwind CSS**](https://tailwindcss.com/) - Utility-first CSS framework
- ๐Ÿงฉ [**shadcn/ui**](https://ui.shadcn.com/) - Components built with Radix UI and Tailwind CSS
- ๐Ÿ“ [**MDX**](https://mdxjs.com/) - Use markdown with components
- ๐Ÿ“ [**Absolute imports**](https://nextjs.org/docs/app/building-your-application/configuring/absolute-imports-and-module-aliases) - Easier and cleaner module imports
- ๐Ÿ’ป [**VS Code configurations**](https://code.visualstudio.com/) - Configurations for easy debugging

### Testing

- ๐Ÿงช [**Vitest**](https://vitest.dev/) - Flexible testing framework
- ๐Ÿ™ [**React Testing Library**](https://testing-library.com/docs/react-testing-library/intro/) - Maintainable component testing
- ๐Ÿ”— integrates with Vitest as your testing framework
- ๐ŸŽญ [**Playwright**](https://playwright.dev/) - End-to-end testing against multiple environments

### Deployment

- ๐Ÿ“Š [**Bundle analyzer**](https://www.npmjs.com/package/@next/bundle-analyzer) - Analyze bundle sizes in each environment with `pnpm run build:analyze`
- ๐Ÿ“ฆ๐Ÿ’ก [**next-pwa**](https://www.npmjs.com/package/@ducanh2912/next-pwa) - Make your website as a progressive web app (PWA)
- ๐Ÿณ [**Docker**](https://www.docker.com/) - (local and production) Docker-compose and Dockerfiles for running anywhere
- ๐Ÿ”„ [**GitHub Actions**](https://github.com/features/actions) - Robust CI/CD

## ๐ŸŒฑ Getting started

๐Ÿš€ **Option 1: Clone and deploy with Vercel**

[![Vercel](https://vercel.com/button)](https://vercel.com/new/clone?s=https%3A%2F%2Fgithub.com%2FSyhner%2Fnext-kickstart)

๐Ÿ“‹ **Option 2: Clone and run locally**

1. [Fork this repository](https://github.com/syhner/next-kickstart/fork) (uncheck 'Copy the `main` branch only` if you are interested in other branches / feature sets)
2. Clone your new repository
3. Install dependencies and run the development server

- with [pnpm](https://pnpm.io/installation)

```sh
pnpm install
pnpm run dev
```

- or with [Docker](https://docs.docker.com/get-docker/)

```sh
docker-compose --file docker/dev/docker-compose.yml up
```

## โš™๏ธ Configuration

### [Docker](https://www.docker.com/)

- [`.dockerignore`](.dockerignore)
- [`docker/`](docker/) - Dockerfile and docker-compose.yml for development and production

### [Drizzle](https://orm.drizzle.team/)

๐Ÿ’ก (requires enabling)

- [`src/db/`](src/db/)
- [`src/lib/db.ts`](src/lib/db.ts)
- [`drizzle.config.ts`](drizzle.config.ts)

### [ESLint](https://eslint.org/)

- [`.eslintrc.json`](.eslintrc.json)

### [GitHub Actions](https://github.com/features/actions)

- [`.github/workflows/ci.yml`](.github/workflows/ci.yml) - type-checking and linting (hence these errors are ignored in [`next.config.mjs`](next.config.mjs))

### [Lucia Auth](https://lucia-auth.com/)

๐Ÿ’ก (requires enabling)

- [`src/app/api/auth`](src/app/api/auth)
- [`src/app/auth`](src/app/auth)
- [`src/components/auth.tsx`](src/components/auth.tsx)
- [`src/db/schemas/auth.ts)`](src/db/schemas/auth.ts) store auth data in database
- [`src/lib/auth.ts`](src/lib/auth.ts)
- [`types/lucia.d.ts`](types/lucia.d.ts)

#### Examples

- [`src/app/examples/profile/page.tsx`](src/app/examples/profile/page.tsx)

### [MDX](https://mdxjs.com/)

- [`mdx-components.tsx`](mdx-components.tsx)

### [next-pwa](https://www.npmjs.com/package/@ducanh2912/next-pwa)

- [`public/icon-512x512.png`](public/icon-512x512.png)
- [`public/manifest.json`](public/manifest.json)
- [`next.config.mjs`](next.config.mjs)

### [Playwright](https://playwright.dev/)

- [`e2e/`](e2e/)
- [`playwright.config.ts`](playwright.config.ts)

### [Prettier](https://prettier.io/)

- [`.eslintrc.json`](.eslintrc.json)
- [`.prettierignore`](.prettierignore)
- [`.prettierrc.json`](.prettierrc.json)

### [React Testing Library](https://testing-library.com/docs/react-testing-library/intro/)

- [`src/app/page.test.tsx`](src/app/page.test.tsx)
- [`testing/setup.ts`](testing/setup.ts)

### [shadcn/ui](https://ui.shadcn.com/)

- [`src/components/providers/theme-provider.tsx`](src/components/providers/theme-provider.tsx)
- [`src/components/ui/`](src/components/ui/)
- [`src/components/theme-toggle.tsx`](src/components/theme-toggle.tsx)
- [`components.json`](components.json)

### [T3 Env](https://github.com/t3-oss/t3-env)

- [`src/env.mjs`](src/env.mjs) - configure environment variables
- [`next.config.mjs`](next.config.mjs) - environment variables are validated at build-time

### [Tailwind CSS](https://tailwindcss.com/)

- [`src/styles/globals.css`](src/styles/globals.css)
- [`tailwind.config.js`](tailwind.config.js)

### [tRPC](https://trpc.io/)

- [`src/app/api/trpc/[trpc]/route.ts`](src/components/providers/trpc-provider.tsx)
- [`src/components/providers/trpc-provider.tsx`](src/app/api/trpc/[trpc]/route.ts)
- [`src/trpc/`](src/trpc)

#### Examples

- [`src/app/examples/client-component/page.tsx`](src/app/examples/client-component/page.tsx) - use in a client component
- [`src/app/examples/server-component/page.tsx`](src/app/examples/server-component/page.tsx) - use in a server component

### [TypeScript](https://www.typescriptlang.org/)

- [`tsconfig.json`](tsconfig.json) - all modifications from [create-next-app](https://www.npmjs.com/package/create-next-app) are explained with comments
- [`types/reset.d.ts`](types/reset.d.ts) - using [ts-reset](https://github.com/total-typescript/ts-reset) to increase type-safety

### [Vitest](https://vitest.dev/)

- [`testing/setup.ts`](testing/setup.ts)
- [`vitest.config.ts`](vitest.config.ts)

### [VS Code](https://code.visualstudio.com/)

- [`.vscode/extensions.json`](.vscode/extensions.json) - recommended workspace extensions
- [`.vscode/launch.json`](.vscode/launch.json) - debug configurations
- [`.vscode/settings.json`](.vscode/settings.json) - use project TypeScript version

### [WebSockets with Pusher](https://pusher.com)

๐Ÿ’ก (requires enabling)

- [`src/hooks/useEvent.ts`](src/hooks/useEvent.ts)
- [`src/lib/events.ts`](src/lib/events.ts)
- [`src/trpc/methods.ts`](src/trpc/methods.ts)

#### Examples

- [`src/app/examples/websockets/page.tsx`](src/app/examples/websockets/page.tsx)