mirror of
https://github.com/soconnor0919/hristudio.git
synced 2026-03-24 03:37:51 -04:00
147 lines
4.8 KiB
TypeScript
147 lines
4.8 KiB
TypeScript
import {
|
|
BookOpen,
|
|
FlaskConical,
|
|
PlayCircle,
|
|
BarChart3,
|
|
HelpCircle,
|
|
FileText,
|
|
Video,
|
|
ExternalLink,
|
|
} from "lucide-react";
|
|
import {
|
|
Card,
|
|
CardContent,
|
|
CardDescription,
|
|
CardHeader,
|
|
CardTitle,
|
|
} from "~/components/ui/card";
|
|
import { Button } from "~/components/ui/button";
|
|
import { PageLayout } from "~/components/ui/page-layout";
|
|
import Link from "next/link";
|
|
|
|
export default function HelpCenterPage() {
|
|
const guides = [
|
|
{
|
|
title: "Getting Started",
|
|
description: "Learn the basics of HRIStudio and set up your first study.",
|
|
icon: BookOpen,
|
|
items: [
|
|
{ label: "Platform Overview", href: "#" },
|
|
{ label: "Creating a New Study", href: "#" },
|
|
{ label: "Managing Team Members", href: "#" },
|
|
],
|
|
},
|
|
{
|
|
title: "Designing Experiments",
|
|
description: "Master the visual experiment designer and flow control.",
|
|
icon: FlaskConical,
|
|
items: [
|
|
{ label: "Using the Visual Designer", href: "#" },
|
|
{ label: "Robot Actions & Plugins", href: "#" },
|
|
{ label: "Variables & Logic", href: "#" },
|
|
],
|
|
},
|
|
{
|
|
title: "Running Trials",
|
|
description: "Execute experiments and manage Wizard of Oz sessions.",
|
|
icon: PlayCircle,
|
|
items: [
|
|
{ label: "Wizard Interface Guide", href: "#" },
|
|
{ label: "Participant Management", href: "#" },
|
|
{ label: "Handling Robot Errors", href: "#" },
|
|
],
|
|
},
|
|
{
|
|
title: "Analysis & Data",
|
|
description: "Analyze trial results and export research data.",
|
|
icon: BarChart3,
|
|
items: [
|
|
{ label: "Understanding Analytics", href: "#" },
|
|
{ label: "Exporting Data (CSV/JSON)", href: "#" },
|
|
{ label: "Video Replay & Annotation", href: "#" },
|
|
],
|
|
},
|
|
];
|
|
|
|
return (
|
|
<PageLayout
|
|
title="Help Center"
|
|
description="Documentation, guides, and support for HRIStudio researchers."
|
|
>
|
|
<div className="grid gap-6 md:grid-cols-2">
|
|
{guides.map((guide, index) => (
|
|
<Card key={index}>
|
|
<CardHeader>
|
|
<div className="flex items-center gap-2">
|
|
<div className="bg-primary/10 rounded-lg p-2">
|
|
<guide.icon className="text-primary h-5 w-5" />
|
|
</div>
|
|
<CardTitle className="text-xl">{guide.title}</CardTitle>
|
|
</div>
|
|
<CardDescription>{guide.description}</CardDescription>
|
|
</CardHeader>
|
|
<CardContent>
|
|
<ul className="space-y-2">
|
|
{guide.items.map((item, i) => (
|
|
<li key={i}>
|
|
<Button
|
|
variant="link"
|
|
className="text-foreground hover:text-primary h-auto justify-start p-0 font-normal"
|
|
asChild
|
|
>
|
|
<Link href={item.href}>
|
|
<FileText className="text-muted-foreground mr-2 h-4 w-4" />
|
|
{item.label}
|
|
</Link>
|
|
</Button>
|
|
</li>
|
|
))}
|
|
</ul>
|
|
</CardContent>
|
|
</Card>
|
|
))}
|
|
</div>
|
|
|
|
<div className="mt-8">
|
|
<h2 className="mb-4 text-2xl font-bold tracking-tight">
|
|
Video Tutorials
|
|
</h2>
|
|
<div className="grid gap-6 md:grid-cols-3">
|
|
{[
|
|
"Introduction to HRIStudio",
|
|
"Advanced Flow Control",
|
|
"ROS2 Integration Deep Dive",
|
|
].map((title, i) => (
|
|
<Card key={i} className="overflow-hidden">
|
|
<div className="bg-muted group hover:bg-muted/80 relative flex aspect-video cursor-pointer items-center justify-center transition-colors">
|
|
<PlayCircle className="text-muted-foreground group-hover:text-primary h-12 w-12 transition-colors" />
|
|
</div>
|
|
<CardHeader className="p-4">
|
|
<CardTitle className="text-base">{title}</CardTitle>
|
|
</CardHeader>
|
|
</Card>
|
|
))}
|
|
</div>
|
|
</div>
|
|
|
|
<div className="bg-muted/50 mt-8 rounded-xl border p-8 text-center">
|
|
<div className="bg-background mx-auto mb-4 flex h-12 w-12 items-center justify-center rounded-full shadow-sm">
|
|
<HelpCircle className="text-primary h-6 w-6" />
|
|
</div>
|
|
<h2 className="mb-2 text-xl font-semibold">Still need help?</h2>
|
|
<p className="text-muted-foreground mx-auto mb-6 max-w-md">
|
|
Contact your system administrator or check the official documentation
|
|
for technical support.
|
|
</p>
|
|
<div className="flex justify-center gap-4">
|
|
<Button variant="outline" className="gap-2">
|
|
<ExternalLink className="h-4 w-4" />
|
|
Official Docs
|
|
</Button>
|
|
<Button className="gap-2">Contact Support</Button>
|
|
</div>
|
|
</div>
|
|
</PageLayout>
|
|
);
|
|
}
|