A fullstack English words study website built with remix-t3-stack
- end-to-end type safe by
trpc
- get
myUserInfo
anywhere byuseMyUserInfo
- type safe form with
zod
byuseZodForm
- no need to export
action
in routes, just calltrpcClient.action
to mutate anywhere - request with permission control by
trpc middlewares
- deploy by
docker
- support dark mode by
useAppTheme
- use
drizzle
to keep type safe withpostgresql
db - toast request error automatically
- always use latest remix (react-router v7) features
- remix (react-router v7)
- vite
- trpc
- tailwindcss
- nextui
- typescript
- drizzle
- postgresql
- jwt
- jotai
- pnpm
- react-hook-form
- react-query
- next-themes
- lucide-icons
- zod
- docker
- clone this repository
git clone git@github.com:SteveSuv/remix-words-funny.git
- install packages
npm i pnpm -g
pnpm i
- init database
- install docker and start docker service
- first run command below to create a local postgres container (you can replace the
POSTGRES_PASSWORD_EXAMPLE
):
docker run -d --name postgres -p 5432:5432 -v postgres_data:/var/lib/postgresql/data -e POSTGRES_USER=postgres -e POSTGRES_PASSWORD=POSTGRES_PASSWORD_EXAMPLE -e POSTGRES_DB=wordsfunny postgres:16-alpine
- run command
pnpm db:push
to sync db structs and drizzle schema - download csv data file: https://mypikpak.com/s/VOEs95bTB0KGAg75t0Nrs-oOo1
- use your favorite db tool like TablePlus to connect the postgres db
- insert db data by import csv files to tables. Notice! you should first import
Book
, thenWord
, then others, because tables have some relations. - run
pnpm db:task
, if printtotal words count: 152543
means the postgres db is running ok
- init email server (optional, if you don't want to send login verify code)
- when you dev local, you can just print the verify code simply
- when you deploy to prod, you can use some email server saas like resend
- or you can enable some email server's SMTP, then add
EMAIL_SERVER_ADDRESS
andEMAIL_SERVER_PASS
to .env file, like Netease Email or QQ Email
- run dev server
pnpm dev
- build and preview
pnpm build
pnpm start
deploy by docker
pnpm run deploy
deploy by pm2
# push files to server
rsync -avz build node_modules package.json .env root@HOST:~/remix-words-funny/
# ssh server and run app
ssh root@HOST "cd ~/remix-words-funny && pm2 start npm -- start"
- suggest node version greater than 22
- when you dev local, you should run
docker stop wordsfunny-app
first to stop container to avoid port 3001 occupation - words resource repo
- more features will be added gradually
- a more simply
remix-t3-stack
project for beginners is here: remix-t3-stack