Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
79 changes: 1 addition & 78 deletions src/app/dashboard/page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -91,84 +91,7 @@ export default function Dashboard() {

{/* Sidebar */}
<div className="space-y-8">
{isLoading ? (
<div className="bg-white dark:bg-gray-900 rounded-2xl shadow-sm border dark:border-gray-800 p-8">
<ListSkeleton count={4} />
</div>
) : (
<>
<div className="bg-white dark:bg-gray-900 rounded-2xl shadow-sm border dark:border-gray-800 p-8">
<h3 className="text-xl font-bold text-gray-900 dark:text-white mb-6">
{t('dashboard.quickActions')}
</h3>
<div className="space-y-4">
<button className="w-full text-left p-4 bg-blue-50 dark:bg-blue-900/20 hover:bg-blue-100 dark:hover:bg-blue-900/30 rounded-2xl transition-all group">
<div className="font-bold text-blue-900 dark:text-blue-300 group-hover:translate-x-1 transition-transform">
{t('dashboard.continueLearning')}
</div>
<div className="text-sm text-blue-700 dark:text-blue-400/80 mt-1">
Web3 UX Design Principles
</div>
</button>

<button className="w-full text-left p-4 bg-green-50 dark:bg-green-900/20 hover:bg-green-100 dark:hover:bg-green-900/30 rounded-2xl transition-all group">
<div className="font-bold text-green-900 dark:text-green-300 group-hover:translate-x-1 transition-transform">
{t('dashboard.downloadCourse')}
</div>
<div className="text-sm text-green-700 dark:text-green-400/80 mt-1">
{t('dashboard.offlineAccess')}
</div>
</button>

<button className="w-full text-left p-4 bg-purple-50 dark:bg-purple-900/20 hover:bg-purple-100 dark:hover:bg-purple-900/30 rounded-2xl transition-all group">
<div className="font-bold text-purple-900 dark:text-purple-300 group-hover:translate-x-1 transition-transform">
{t('dashboard.viewProgress')}
</div>
<div className="text-sm text-purple-700 dark:text-purple-400/80 mt-1">
{t('dashboard.trackLearning')}
</div>
</button>
</div>
</div>

<div className="bg-white dark:bg-gray-900 rounded-2xl shadow-sm border dark:border-gray-800 p-8">
<h3 className="text-xl font-bold text-gray-900 dark:text-white mb-6">
{t('dashboard.recentActivity')}
</h3>
<div className="space-y-6">
<div className="flex items-start gap-4 group">
<div className="w-3 h-3 bg-blue-500 rounded-full mt-1.5 ring-4 ring-blue-50 dark:ring-blue-900/20" />
<div>
<p className="font-bold text-gray-900 dark:text-white">
{t('dashboard.completedLesson')}
</p>
<p className="text-sm text-gray-500 dark:text-gray-400">
{t('dashboard.activityEntry', {
course: 'Web3 UX Design',
time: t('dashboard.timeHoursAgo', { count: 2 }),
})}
</p>
</div>
</div>

<div className="flex items-start gap-4 group">
<div className="w-3 h-3 bg-green-500 rounded-full mt-1.5 ring-4 ring-green-50 dark:ring-green-900/20" />
<div>
<p className="font-bold text-gray-900 dark:text-white">
{t('dashboard.downloadedCourse')}
</p>
<p className="text-sm text-gray-500 dark:text-gray-400">
{t('dashboard.activityEntry', {
course: 'Smart Contracts',
time: t('dashboard.timeDayAgo', { count: 1 }),
})}
</p>
</div>
</div>
</div>
</div>
</>
)}
<SidebarNavigation />
</div>
</div>
</div>
Expand Down
49 changes: 49 additions & 0 deletions src/components/navigation/SidebarNavigation.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
'use client';

import React from 'react';
import Link from 'next/link';
import { Home, BookOpen, Users, Settings } from 'lucide-react';

interface NavItem {
href: string;
label: string;
icon: React.ComponentType<{ size?: number; className?: string }>;
}

const navItems: NavItem[] = [
{ href: '/', label: 'Home', icon: Home },
{ href: '/courses', label: 'Courses', icon: BookOpen },
{ href: '/workshops', label: 'Workshops', icon: Settings },
{ href: '/profile', label: 'Profile', icon: Users },
];

export const SidebarNavigation: React.FC = () => {
const pathname = typeof window !== 'undefined' ? window.location.pathname : '';
return (
<aside className="w-full lg:w-72 shrink-0 space-y-8 pr-2">
<div className="glass-panel p-5 rounded-xl">
<h3 className="text-xs font-mono font-bold text-gray-500 uppercase tracking-widest mb-4">
Navigation
</h3>
<ul className="space-y-2">
{navItems.map((item) => {
const isActive = pathname === item.href;
return (
<li key={item.href}>
<Link
href={item.href}
className={`flex items-center gap-3 p-2 rounded-lg transition-colors duration-200
${isActive ? 'bg-blue-100 dark:bg-blue-900 text-blue-600' : 'text-gray-600 hover:bg-gray-100 dark:hover:bg-gray-800'}
`}
>
<item.icon size={20} className="flex-shrink-0" />
<span>{item.label}</span>
</Link>
</li>
);
})}
</ul>
</div>
</aside>
);
};
Loading