Skip to content

Interval Repeat Flashcard Demo with Basic Simple Features Designed based on Next.js App Router, ts-fsrs, fsrs-browser and Prisma.

License

Notifications You must be signed in to change notification settings

ishiko732/ts-fsrs-demo

Repository files navigation

TS-FSRS-Demo

introduction

Interval Repeat Flashcard Demo with Basic Simple Features Designed based on Next.js App Router, ts-fsrs, and Prisma.

use packages:

- prisma (global) npm install -g prisma
- next.js (>= 14.2.0)
- ts-fsrs (>= 3.5.3)
- tailwindcss (>= 3)
- shadcn 
- fsrs-browser (>= 0.6.1)

Environment Variables

 An environment variable is a key value pair of string data that is stored on your machine's local environment. Refer to our Environment variables reference documentation for specific details.

Ref(prisma docs): https://www.prisma.io/docs/guides/development-environment/environment-variables

 .env  

DATABASE_URL="postgres://username:password@host:port/database?sslmode=require"
DATABASE_URL_WITH_SCHEMA=${DATABASE_URL}&schema=fsrsDemo 
# example
DATABASE_URL="postgres://default:[email protected]:5432/verceldb?sslmode=require&schema=fsrs"

NEXTAUTH_URL=http://localhost:3000
NEXTAUTH_SECRET=**** # openssl rand -base64 32

# GitHub OAuth https://github.com/settings/developers
GITHUB_ID=***
GITHUB_SECRET=***

# if need lingq server
LINGQ_KEY=**** # copy from http://localhost:3000/api/lingq/key

update schema: src/prisma/schema.prisma

datasource db {
  provider     = "postgresql" // or mysql
  url          = env("DATABASE_URL")
}

How to run?

  • run docker make sure the database is running on your machine: docker-compose up
  • Configure the database environment and use npm run db:push
  • Run demo
npm run dev # or yarn dev/ pnpm dev/ bun dev

Preview

Home

home

Tip: ts-fsrs version:3.5.3

Notes

Notes

You can view the added note information and status here, and click on each note to enter the detailed note page.

note detail note forget

You can view detailed information about the note on this page, and you can click "forget" to reset the learning status of that card.

Review

question show answer

You can perform review operations on the review page, and it is possible to display the answer using the keyboard. You can also schedule the timing and use Ctrl+Z or ⌘+Z to undo or revert the operation.

finish

After completing the review, you will be prompted accordingly.

Settings

setting-button

Click on the button, and you can set up.

FSRS Settings

You can customize the parameters of your FSRS params

Train

use fsrs-browser to train.

API Router: http://localhost:3000/api/fsrs/train nodejs train

Client: http://localhost:3000/train training

Build

You can compile the demo for better performance by using npm run build, and then start the project using npm run start. build demo