From 2d617f236fa3fbd39a0a7def23199a36cfa0b4c2 Mon Sep 17 00:00:00 2001 From: nsfisis Date: Wed, 4 Feb 2026 22:51:01 +0900 Subject: fix(study): use 3 AM boundary for counting today's new card reviews countTodayNewCardReviews was using midnight (0:00) as the start of day, inconsistent with the 3 AM study day boundary used elsewhere. Reviews between 0:00-3:00 AM were incorrectly counted as the next day's budget. Co-Authored-By: Claude Opus 4.5 --- src/server/repositories/review-log.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src/server') diff --git a/src/server/repositories/review-log.ts b/src/server/repositories/review-log.ts index 591c647..97488d2 100644 --- a/src/server/repositories/review-log.ts +++ b/src/server/repositories/review-log.ts @@ -1,4 +1,5 @@ import { and, eq, gte, sql } from "drizzle-orm"; +import { getStartOfStudyDayBoundary } from "../../shared/date.js"; import { db } from "../db/index.js"; import { CardState, cards, reviewLogs } from "../db/schema.js"; import type { ReviewLog, ReviewLogRepository } from "./types.js"; @@ -32,8 +33,7 @@ export const reviewLogRepository: ReviewLogRepository = { }, async countTodayNewCardReviews(deckId: string, now: Date): Promise { - const startOfDay = new Date(now); - startOfDay.setHours(0, 0, 0, 0); + const startOfDay = getStartOfStudyDayBoundary(now); const result = await db .select({ count: sql`count(distinct ${reviewLogs.cardId})::int` }) -- cgit v1.3-1-g0d28