/Nextjs-Dashboard

Dashboard own craft

Primary LanguageTypeScript

Nextjs-Dashboard

Handicraft Dashboard

Nextjs 15 (rc) - TypeScript - Tailwind - PostgreSQL

Dashboard Img

Introduction

Although this application seems complete, I focused on the administrator dashboard features, in order to create something both useful and original. I also used NextAuth v5 to see how it's possible to log in as both user and administrator. In the real world, you'd have to use Lucia instead.

I'm interested in :

  • capturing the public IP and then using it for geolocation.
  • how to retrieve users' browser and os system data and display them in graphs.

Display :

  • product stocks in order from smallest to largest.
  • connected users.
  • messages, connections and sales by day, month and year.
  • tasks set by administrators on all pages of the application.

Goals

Login as User or Admin with NextAuth V5 without api (GitHub & Google)

  • Administrator can access to dashboard.
  • User & Admin can access to products & payment.

User:

  • main page
  • products
  • contact (possibility to send message to admin)

Admin:

  • main page
  • dashboard

Dashboard with multiple management system:

  • message
  • statistics
  • users
  • products (best sellers & stock)
  • bilan

Fetch the public IP from user

Retrieve the public IP & determine the location by latitude & longitude with react-leaflet map.

https://jsonip.com/

Fetch to retrieve latitude & longitude with SECRET_API_KEY & publicIp to customize url, such as:

https://api.ip2location.io/?key=${SECRET_API_KEY}&ip=${publicIp}

(You can use the api free of charge with https://www.ip2location.io/).

I had some problems, many times, with a window is undefined error. To solve this problem in my RSC (React Server Component), I simply added :

export const dynamic = "force-dynamic";

Data are displayed under Network link in Dashboard.


Retrieve Browser & OS from users

Display them to user & write them into a file

Useful link: window.navigator.userAgent

Data are written into:

  • /app/api/profile/browseros/route.ts

Data are saved into:

  • /utils/browseros-data.json
  • /utils/ip-data.json

Data are displayed in charts

  • components/menu-items/graphs/BarChartBrowser.tsx
  • components/menu-items/graphs/BarChartOs.tsx

Manage products from store as ADMIN with server-actions & postgresql (prisma)

dashboard (admin)

  1. Upadate/Modify
  2. Delete
  3. Create
  • /components/menu-items/admin-products/ModifyProduct.tsx
  • /components/menu-items/admin-products/CreateProduct.tsx

(They have the same route)


Messages

User can send message to Admin & management system message for Admin

contact (user)

  • Write & send a message to admin.

dashboard (admin)

  • Open/close messages
  • Read & write message to response to users.

Data

Retrieve data from db & data.json to display values in charts

dashboard (admin)

  • Messages
  • Network
  • Statistics (nb connection to site per day, os, browser, satisfaction)
  • Store of products (create - delete - update)
  • Bilan

Configuration in .env

POSTGRES_HOST=127.0.0.1
POSTGRES_PORT=PPPPPPPPP
POSTGRES_USER=UUUU
POSTGRES_PASSWORD=XXXX
POSTGRES_DB=DBDBDBD

DATABASE_URL="postgresql://UUUU:XXXX@localhost:PPPPPPPPP/DBDBDBD?schema=public"

# use: "openssl rand -base64 32"
AUTH_SECRET="result of cmd above"
NEXTAUTH_URL=http://localhost:3000

# build mode require this setting:
AUTH_TRUST_HOST=true

Don't forget to configure .gitignore to avoid share sensitive data.

add .env into .gitignore & save the file.


Authentication with next-auth@beta

I wanted build a system login without external API like Google or GitHub to give different access as user or admin.

All files that include NextAuth V5:

  • app/api/auth/[...nextauth]/route.ts
  • /app/auth/...
  • middleware.ts
  • prisma/prisma.ts

Security

Use next-safe-action with zod & zod-form-data, to secure request of server action (avoid to display sensitive data). It's interacts with the middleware.

  • /lib/actions.ts
  • /lib/safe-action.ts

Extra

I create a shop as an e-commerce to combine zustand with prisma request. Just to understand how works prisma table (in this ctx) & how to initialize products in the zustand store. I don't used stripe, because that wasn't my goal.


Installation

$ pnpm add sharp

$ pnpm add react-icons

$ pnpm tailwindcss-animate

$ pnpm add chart.js react-chartjs-2

$ pnpm add leaflet

$ pnpm add react-leaflet

(not required @types/react-leaflet = deprecated)

$ pnpm add zustand

$ pnpm add @tanstack/react-query

$ pnpm add @tanstack/react-query-devtools

$ pnpm add jsonwebtoken

$ pnpm add @types/jsonwebtoken

$ pnpm add react-hook-form

$ pnpm add zod @hookform/resolvers

$ pnpm add zod-form-data

$ pnpm add @hookform/error-message

$ pnpm add next-auth@beta @auth/prisma-adapter

$ pnpm add @prisma/client

$ pnpm add -D prisma

$ pnpm prisma init --datasource-provider postgresql

(create db & table with PostgreSQL)

$ pnpm prisma migrate dev --name init

(pnpm prisma db push (schema))

(pnpm prisma db seed (seed.ts))

$ pnpm add bcryptjs

$ pnpm add -D @types/bcryptjs

$ pnpm add react-hot-toast

$ pnpm add next-safe-action

Video Youtube

IMAGE ALT TEXT HERE

Ref

  • NextAuth V5:

auth.ts

  • If you get some trouble with prisma migration schema, follow this link:

prisma-migrate


Enjoy it ! 🐨: