Files
hristudio/src/app/(dashboard)/trials/[trialId]/wizard/page.tsx
Sean O'Connor 433c1c4517 docs: consolidate and restructure documentation architecture
- Remove outdated root-level documentation files
  - Delete IMPLEMENTATION_STATUS.md, WORK_IN_PROGRESS.md, UI_IMPROVEMENTS_SUMMARY.md, CLAUDE.md

- Reorganize documentation into docs/ folder
  - Move UNIFIED_EDITOR_EXPERIENCES.md → docs/unified-editor-experiences.md
  - Move DATATABLE_MIGRATION_PROGRESS.md → docs/datatable-migration-progress.md
  - Move SEED_SCRIPT_README.md → docs/seed-script-readme.md

- Create comprehensive new documentation
  - Add docs/implementation-status.md with production readiness assessment
  - Add docs/work-in-progress.md with active development tracking
  - Add docs/development-achievements.md consolidating all major accomplishments

- Update documentation hub
  - Enhance docs/README.md with complete 13-document structure
  - Organize into logical categories: Core, Status, Achievements
  - Provide clear navigation and purpose for each document

Features:
- 73% code reduction achievement through unified editor experiences
- Complete DataTable migration with enterprise features
- Comprehensive seed database with realistic research scenarios
- Production-ready status with 100% backend, 95% frontend completion
- Clean documentation architecture supporting future development

Breaking Changes: None - documentation restructuring only
Migration: Documentation moved to docs/ folder, no code changes required
2025-08-04 23:54:47 -04:00

100 lines
3.0 KiB
TypeScript

import { notFound, redirect } from "next/navigation";
import { WizardInterface } from "~/components/trials/wizard/WizardInterface";
import { auth } from "~/server/auth";
import { api } from "~/trpc/server";
interface WizardPageProps {
params: Promise<{
trialId: string;
}>;
}
export default async function WizardPage({ params }: WizardPageProps) {
const session = await auth();
if (!session) {
redirect("/auth/signin");
}
// Check if user has wizard/researcher permissions
const userRole = session.user.roles?.[0]?.role;
if (
!userRole ||
!["wizard", "researcher", "administrator"].includes(userRole)
) {
redirect("/trials?error=insufficient_permissions");
}
const { trialId } = await params;
let trial;
try {
trial = await api.trials.get({ id: trialId });
} catch (_error) {
notFound();
}
// Only allow wizard interface for scheduled or in-progress trials
if (!["scheduled", "in_progress"].includes(trial.status)) {
redirect(`/trials/${trialId}?error=trial_not_active`);
}
return (
<div className="min-h-screen bg-slate-50">
{/* Header */}
<div className="border-b border-slate-200 bg-white px-6 py-4">
<div className="flex items-center justify-between">
<div>
<h1 className="text-2xl font-bold text-slate-900">
Wizard Control Interface
</h1>
<p className="mt-1 text-sm text-slate-600">
{trial.experiment.name} Participant:{" "}
{trial.participant.participantCode}
</p>
</div>
<div className="flex items-center space-x-2">
<div
className={`flex items-center space-x-2 rounded-full px-3 py-1 text-sm font-medium ${
trial.status === "in_progress"
? "bg-green-100 text-green-800"
: "bg-blue-100 text-blue-800"
}`}
>
<div
className={`h-2 w-2 rounded-full ${
trial.status === "in_progress"
? "animate-pulse bg-green-500"
: "bg-blue-500"
}`}
></div>
{trial.status === "in_progress"
? "Trial Active"
: "Ready to Start"}
</div>
</div>
</div>
</div>
{/* Main Wizard Interface */}
<WizardInterface trial={trial} userRole={userRole} />
</div>
);
}
// Generate metadata for the page
export async function generateMetadata({ params }: WizardPageProps) {
try {
const { trialId } = await params;
const trial = await api.trials.get({ id: trialId });
return {
title: `Wizard Control - ${trial.experiment.name} | HRIStudio`,
description: `Real-time wizard control interface for trial ${trial.participant.participantCode}`,
};
} catch {
return {
title: "Wizard Control | HRIStudio",
description: "Real-time wizard control interface for HRI trials",
};
}
}