- Add GraphQL dashboard operations, ApolloProvider, CardDescription, label/checkbox/alert - Fix case-sensitive UI imports, Crossplane VM metadata uid, VMList spec parsing - Extend next-auth session user (id, role); fairness filters as unknown; ESLint relax to warnings - Remove unused session destructure across pages; next.config without skip TS/ESLint api: GraphQL/WebSocket hardening, logger import in websocket service Made-with: Cursor
114 lines
4.1 KiB
TypeScript
114 lines
4.1 KiB
TypeScript
'use client';
|
|
|
|
import { useSession } from 'next-auth/react';
|
|
import { signIn } from 'next-auth/react';
|
|
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/Card';
|
|
import { Handshake, TrendingUp, BookOpen, Package, ArrowRight } from 'lucide-react';
|
|
import Link from 'next/link';
|
|
|
|
export default function PartnerPortalPage() {
|
|
const { status } = useSession();
|
|
|
|
if (status === 'loading') {
|
|
return (
|
|
<div className="flex min-h-screen items-center justify-center bg-gray-900">
|
|
<div className="text-center">
|
|
<div className="mb-4 h-8 w-8 animate-spin rounded-full border-4 border-gray-300 border-t-blue-600 mx-auto"></div>
|
|
<p className="text-gray-400">Loading...</p>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
if (status === 'unauthenticated') {
|
|
return (
|
|
<div className="flex min-h-screen items-center justify-center bg-gray-900">
|
|
<div className="text-center max-w-md mx-auto p-8">
|
|
<h1 className="text-2xl font-bold text-white mb-4">Welcome to Partner Portal</h1>
|
|
<p className="text-gray-400 mb-6">Please sign in to continue</p>
|
|
<button
|
|
onClick={() => signIn()}
|
|
className="px-6 py-3 bg-blue-600 text-white rounded-lg hover:bg-blue-700 transition-colors"
|
|
>
|
|
Sign In
|
|
</button>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
const partnerSections = [
|
|
{
|
|
title: 'Co-Sell Deal Management',
|
|
description: 'Register and manage co-sell deals with Sankofa',
|
|
icon: Handshake,
|
|
href: '/partner/deals',
|
|
features: ['Deal registration', 'Deal tracking', 'Revenue sharing'],
|
|
},
|
|
{
|
|
title: 'Technical Onboarding',
|
|
description: 'Access technical resources and onboarding materials',
|
|
icon: BookOpen,
|
|
href: '/partner/onboarding',
|
|
features: ['Technical training', 'Architecture guides', 'Best practices'],
|
|
},
|
|
{
|
|
title: 'Solution Registration',
|
|
description: 'Register your solutions in the marketplace',
|
|
icon: Package,
|
|
href: '/partner/solutions',
|
|
features: ['Solution listing', 'Certification', 'Marketplace access'],
|
|
},
|
|
{
|
|
title: 'Partner Resources',
|
|
description: 'Marketing materials, sales enablement, and training resources',
|
|
icon: TrendingUp,
|
|
href: '/partner/resources',
|
|
features: ['Marketing assets', 'Sales materials', 'Training programs'],
|
|
},
|
|
];
|
|
|
|
return (
|
|
<div className="container mx-auto px-4 py-8">
|
|
<div className="mb-8">
|
|
<h1 className="text-3xl font-bold text-white mb-2">Partner Portal</h1>
|
|
<p className="text-gray-400">Co-sell deals, technical onboarding, and solution registration</p>
|
|
</div>
|
|
|
|
<div className="grid grid-cols-1 md:grid-cols-2 gap-6">
|
|
{partnerSections.map((section) => {
|
|
const Icon = section.icon;
|
|
return (
|
|
<Card key={section.href} className="bg-gray-800 border-gray-700 hover:border-orange-500 transition-colors">
|
|
<CardHeader>
|
|
<div className="flex items-center gap-3 mb-2">
|
|
<Icon className="h-6 w-6 text-orange-500" />
|
|
<CardTitle className="text-white">{section.title}</CardTitle>
|
|
</div>
|
|
<p className="text-sm text-gray-400">{section.description}</p>
|
|
</CardHeader>
|
|
<CardContent>
|
|
<ul className="space-y-2 mb-4">
|
|
{section.features.map((feature) => (
|
|
<li key={feature} className="flex items-center gap-2 text-sm text-gray-300">
|
|
<span className="text-orange-500">•</span>
|
|
<span>{feature}</span>
|
|
</li>
|
|
))}
|
|
</ul>
|
|
<Link
|
|
href={section.href}
|
|
className="inline-flex items-center gap-2 text-sm text-orange-500 hover:text-orange-400 transition-colors"
|
|
>
|
|
Access <ArrowRight className="h-4 w-4" />
|
|
</Link>
|
|
</CardContent>
|
|
</Card>
|
|
);
|
|
})}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|