|
|
import React, { useState, useEffect } from 'react';
|
|
|
import { Search, Bell, Settings, Sun, Moon } from 'lucide-react';
|
|
|
|
|
|
interface HeaderProps {
|
|
|
currentPage?: string;
|
|
|
}
|
|
|
|
|
|
export const Header: React.FC<HeaderProps> = ({ currentPage = 'Dashboard' }) => {
|
|
|
const [theme, setTheme] = useState<'light' | 'dark'>('dark');
|
|
|
const [searchQuery, setSearchQuery] = useState('');
|
|
|
|
|
|
useEffect(() => {
|
|
|
const savedTheme = localStorage.getItem('theme') as 'light' | 'dark' || 'dark';
|
|
|
setTheme(savedTheme);
|
|
|
document.documentElement.setAttribute('data-theme', savedTheme);
|
|
|
}, []);
|
|
|
|
|
|
const toggleTheme = () => {
|
|
|
const newTheme = theme === 'light' ? 'dark' : 'light';
|
|
|
setTheme(newTheme);
|
|
|
localStorage.setItem('theme', newTheme);
|
|
|
document.documentElement.setAttribute('data-theme', newTheme);
|
|
|
};
|
|
|
|
|
|
const handleSearch = (e: React.FormEvent) => {
|
|
|
e.preventDefault();
|
|
|
if (searchQuery.trim()) {
|
|
|
console.log('Search query:', searchQuery);
|
|
|
|
|
|
}
|
|
|
};
|
|
|
|
|
|
return (
|
|
|
<header className="header" role="banner">
|
|
|
{/* Left Section - Breadcrumb */}
|
|
|
<div className="header-left">
|
|
|
<div className="header-breadcrumb">
|
|
|
<div className="breadcrumb-item">
|
|
|
<a href="/">
|
|
|
<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2" strokeLinecap="round" strokeLinejoin="round">
|
|
|
<path d="m3 9 9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z"/>
|
|
|
<polyline points="9 22 9 12 15 12 15 22"/>
|
|
|
</svg>
|
|
|
</a>
|
|
|
</div>
|
|
|
<span className="breadcrumb-separator">/</span>
|
|
|
<div className="breadcrumb-item active">
|
|
|
<span>{currentPage}</span>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
{/* Center Section - Search */}
|
|
|
<div className="header-center">
|
|
|
<form className="header-search" onSubmit={handleSearch}>
|
|
|
<Search className="header-search-icon" size={16} />
|
|
|
<input
|
|
|
type="text"
|
|
|
className="header-search-input"
|
|
|
placeholder="Search..."
|
|
|
value={searchQuery}
|
|
|
onChange={(e) => setSearchQuery(e.target.value)}
|
|
|
/>
|
|
|
</form>
|
|
|
</div>
|
|
|
|
|
|
{/* Right Section - Actions */}
|
|
|
<div className="header-right">
|
|
|
{/* API Status Indicator */}
|
|
|
<div className="status-indicator">
|
|
|
<span className="status-dot"></span>
|
|
|
<span>API Live</span>
|
|
|
</div>
|
|
|
|
|
|
{/* Notifications */}
|
|
|
<button className="icon-btn" aria-label="Notifications" title="Notifications">
|
|
|
<Bell size={20} />
|
|
|
</button>
|
|
|
|
|
|
{/* Theme Toggle */}
|
|
|
<button
|
|
|
className="icon-btn"
|
|
|
aria-label="Toggle theme"
|
|
|
title="Toggle theme"
|
|
|
onClick={toggleTheme}
|
|
|
>
|
|
|
{theme === 'light' ? <Sun size={20} /> : <Moon size={20} />}
|
|
|
</button>
|
|
|
|
|
|
{/* Settings */}
|
|
|
<a href="/settings" className="icon-btn" aria-label="Settings" title="Settings">
|
|
|
<Settings size={20} />
|
|
|
</a>
|
|
|
</div>
|
|
|
</header>
|
|
|
);
|
|
|
};
|
|
|
|
|
|
export default Header;
|
|
|
|