Skip to content

Latest commit

 

History

History
64 lines (47 loc) · 2.66 KB

README.md

File metadata and controls

64 lines (47 loc) · 2.66 KB

TypeScript Next.js example

This is a really simple project that shows the usage of Next.js with TypeScript.

Steps to run the project:

  1. Ensure that the nakamoto-coefficient server is running on port 8080.
  2. Build and start the frontend by running the following commands:
npm run build
npm run start
  1. Or, if you want to debug, simply run npm run dev.

Docker image

  1. Build docker image
 docker build . --platform=linux/amd64 -t xenowits/nakamoto-coefficient-frontend:v0.1.0
  1. Push to github container registry
docker push xenowits/nakamoto-coefficient-frontend:v0.1.0
  1. Run docker image
docker run -p 3000:3000 xenowits/nakamoto-coefficient-frontend:v0.1.0
  1. Docker images are available here.

Deploy your own

Deploy the example using Vercel:

Deploy with Vercel

How to use it?

Execute create-next-app with npm or Yarn to bootstrap the example:

npx create-next-app --example with-typescript with-typescript-app
# or
yarn create next-app --example with-typescript with-typescript-app

Deploy it to the cloud with Vercel (Documentation).

Notes

This example shows how to integrate the TypeScript type system into Next.js. Since TypeScript is supported out of the box with Next.js, all we have to do is to install TypeScript.

npm install --save-dev typescript

To enable TypeScript's features, we install the type declarations for React and Node.

npm install --save-dev @types/react @types/react-dom @types/node

When we run next dev the next time, Next.js will start looking for any .ts or .tsx files in our project and builds it. It even automatically creates a tsconfig.json file for our project with the recommended settings.

Next.js has built-in TypeScript declarations, so we'll get autocompletion for Next.js' modules straight away.

A type-check script is also added to package.json, which runs TypeScript's tsc CLI in noEmit mode to run type-checking separately. You can then include this, for example, in your test scripts.