feat(stats): /lessons-progress and /due routes + heatmap default 52 weeks
This commit is contained in:
@@ -1,6 +1,9 @@
|
|||||||
import { Router } from 'express';
|
import { Router } from 'express';
|
||||||
import type { Db } from '../db/client.js';
|
import type { Db } from '../db/client.js';
|
||||||
import { getCardStats, getHeatmap, getLessonStats, getOverview } from '../services/stats.js';
|
import {
|
||||||
|
getCardStats, getHeatmap, getLessonStats, getOverview,
|
||||||
|
getLessonsProgress, getDueOverview,
|
||||||
|
} from '../services/stats.js';
|
||||||
|
|
||||||
export function statsRouter(db: Db): Router {
|
export function statsRouter(db: Db): Router {
|
||||||
const r = Router();
|
const r = Router();
|
||||||
@@ -8,6 +11,12 @@ export function statsRouter(db: Db): Router {
|
|||||||
r.get('/overview', async (req, res, next) => {
|
r.get('/overview', async (req, res, next) => {
|
||||||
try { res.json(await getOverview(db, req.user!.id)); } catch (e) { next(e); }
|
try { res.json(await getOverview(db, req.user!.id)); } catch (e) { next(e); }
|
||||||
});
|
});
|
||||||
|
r.get('/lessons-progress', async (req, res, next) => {
|
||||||
|
try { res.json(await getLessonsProgress(db, req.user!.id)); } catch (e) { next(e); }
|
||||||
|
});
|
||||||
|
r.get('/due', async (req, res, next) => {
|
||||||
|
try { res.json(await getDueOverview(db, req.user!.id)); } catch (e) { next(e); }
|
||||||
|
});
|
||||||
r.get('/lessons/:id', async (req, res, next) => {
|
r.get('/lessons/:id', async (req, res, next) => {
|
||||||
try { res.json(await getLessonStats(db, req.user!.id, Number(req.params.id))); } catch (e) { next(e); }
|
try { res.json(await getLessonStats(db, req.user!.id, Number(req.params.id))); } catch (e) { next(e); }
|
||||||
});
|
});
|
||||||
@@ -16,7 +25,7 @@ export function statsRouter(db: Db): Router {
|
|||||||
});
|
});
|
||||||
r.get('/heatmap', async (req, res, next) => {
|
r.get('/heatmap', async (req, res, next) => {
|
||||||
try {
|
try {
|
||||||
const weeks = Math.min(52, Math.max(1, Number(req.query.weeks ?? 12)));
|
const weeks = Math.min(52, Math.max(1, Number(req.query.weeks ?? 52)));
|
||||||
res.json(await getHeatmap(db, req.user!.id, weeks));
|
res.json(await getHeatmap(db, req.user!.id, weeks));
|
||||||
} catch (e) { next(e); }
|
} catch (e) { next(e); }
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user