Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings
This repository was archived by the owner on Jun 3, 2026. It is now read-only.

Project metric #163

Open
thienkq wants to merge 13 commits into main
base: main
Choose a base branch
Loading
from project-metric
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
13 commits
Select commit Hold shift + click to select a range
7414a24
Add project check-ins feature
thienkq Mar 9, 2026
a836b63
Refactor project check-in UI and add styles
thienkq Mar 9, 2026
84cb9fb
Update ProjectCheckinSession.tsx
thienkq Mar 9, 2026
c91911f
Add My Projects dashboard and dashboard query
thienkq Mar 10, 2026
3aa84bb
Add All Projects dashboard and week selector
thienkq Mar 10, 2026
44149ce
fix lint
thienkq Mar 10, 2026
67b698b
Monthly aggregation & transactional checkin RPC
thienkq Mar 10, 2026
55a4adb
Update queries.ts
thienkq Mar 10, 2026
eacb945
Require evidence comments for extreme scores
thienkq Mar 12, 2026
f77f3b4
Add benchmark guide dialog and show full notes
thienkq Mar 12, 2026
f5c823a
Add leadership dashboard & submission tracking
thienkq Mar 12, 2026
726f68c
fix lint
thienkq Mar 12, 2026
524c686
Use /check-ins for reminder email links
thienkq Mar 23, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
82 changes: 82 additions & 0 deletions src/app/(authenticated)/check-ins/[projectId]/page.tsx
View file Open in desktop
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
import Link from 'next/link';

import { getISOWeek } from 'date-fns/getISOWeek';
import { getISOWeekYear } from 'date-fns/getISOWeekYear';

import { Button } from '@/components/ui/button';
import { Card, CardContent, CardDescription, CardHeader, CardTitle } from '@/components/ui/card';
import { createClient } from '@/utils/supabase/server';
import { getProjectCheckinPageData } from '@/lib/project-checkins/queries';
import ProjectCheckinSession from '../components/ProjectCheckinSession';

type ProjectCheckinProjectPageProps = {
params: Promise<{ projectId: string }>;
searchParams: Promise<{ year?: string; week?: string }>;
};

function parseYearWeek(searchYear?: string, searchWeek?: string): { year: number; weekNumber: number } {
const now = new Date();
const year = searchYear ? parseInt(searchYear, 10) : getISOWeekYear(now);
const weekNumber = searchWeek ? parseInt(searchWeek, 10) : getISOWeek(now);
if (Number.isNaN(year) || Number.isNaN(weekNumber)) {
return { year: getISOWeekYear(now), weekNumber: getISOWeek(now) };
}
return {
year: year >= 2000 && year <= 2100 ? year : getISOWeekYear(now),
weekNumber: weekNumber >= 1 && weekNumber <= 53 ? weekNumber : getISOWeek(now),
};
}

export default async function ProjectCheckinProjectPage({ params, searchParams }: ProjectCheckinProjectPageProps) {
const { projectId } = await params;
const { year: searchYear, week: searchWeek } = await searchParams;
const { year, weekNumber } = parseYearWeek(searchYear, searchWeek);

const supabase = await createClient();
const {
data: { user },
} = await supabase.auth.getUser();

if (!user) {
return null;
}

const data = await getProjectCheckinPageData(user.id, projectId, year, weekNumber);

if (!data.project) {
return (
<div className="mx-auto max-w-3xl px-4 py-8">
<Card className="border-slate-200">
<CardHeader>
<CardTitle>Project not found</CardTitle>
<CardDescription>
This project does not exist or is not available for check-in.
</CardDescription>
</CardHeader>
<CardContent className="flex gap-3">
<Button asChild>
<Link href="/check-ins">Back to check-ins</Link>
</Button>
<Button asChild variant="outline">
<Link href="/check-ins/new">Start new check-in</Link>
</Button>
</CardContent>
</Card>
</div>
);
}

return (
<div className="mx-auto max-w-4xl px-4 py-8 sm:px-6">
<ProjectCheckinSession
project={data.project}
year={year}
weekNumber={weekNumber}
definitions={data.definitions}
previousResponsesByMetric={data.previousResponsesByMetric}
currentSubmission={data.currentSubmission}
currentResponses={data.currentResponses}
/>
</div>
);
}
Loading

AltStyle によって変換されたページ (->オリジナル) /