mirror of
https://github.com/pupperpowell/bibdle.git
synced 2026-04-05 17:33:31 -04:00
43 lines
1.4 KiB
TypeScript
43 lines
1.4 KiB
TypeScript
import { json, error } from '@sveltejs/kit';
|
|
import type { RequestHandler } from './$types';
|
|
import { db } from '$lib/server/db';
|
|
import { dailyCompletions } from '$lib/server/db/schema';
|
|
import { eq, desc } from 'drizzle-orm';
|
|
|
|
export const GET: RequestHandler = async ({ url }) => {
|
|
const anonymousId = url.searchParams.get('anonymousId');
|
|
const localDate = url.searchParams.get('localDate');
|
|
|
|
if (!anonymousId || !localDate) {
|
|
error(400, 'Missing anonymousId or localDate');
|
|
}
|
|
|
|
// Fetch all completion dates for this user (stored as the user's local date)
|
|
const rows = await db
|
|
.select({ date: dailyCompletions.date })
|
|
.from(dailyCompletions)
|
|
.where(eq(dailyCompletions.anonymousId, anonymousId))
|
|
.orderBy(desc(dailyCompletions.date));
|
|
|
|
const completedDates = new Set(rows.map((r) => r.date));
|
|
|
|
// Subtract one calendar day from a YYYY-MM-DD string using UTC arithmetic —
|
|
// this avoids any dependence on the server's local timezone or DST offsets.
|
|
function prevDay(dateStr: string): string {
|
|
const d = new Date(dateStr + 'T00:00:00Z');
|
|
d.setUTCDate(d.getUTCDate() - 1);
|
|
return d.toISOString().slice(0, 10);
|
|
}
|
|
|
|
// Walk backwards from the user's local date, counting consecutive completed days
|
|
let streak = 0;
|
|
let cursor = localDate;
|
|
|
|
while (completedDates.has(cursor)) {
|
|
streak++;
|
|
cursor = prevDay(cursor);
|
|
}
|
|
|
|
return json({ streak: streak < 2 ? 0 : streak });
|
|
};
|