feat: add log level filtering and enhance logging configuration; update UI for improved navigation and settings structure

This commit is contained in:
Wikid82
2025-11-21 21:32:43 -05:00
parent cdc6630a79
commit 3256cc845b
13 changed files with 101 additions and 123 deletions
+56 -7
View File
@@ -39,12 +39,26 @@ export default function Layout({ children }: LayoutProps) {
{ name: 'Domains', path: '/domains', icon: '🌍' },
{ name: 'Certificates', path: '/certificates', icon: '🔒' },
{ name: 'Import Caddyfile', path: '/import', icon: '📥' },
{ name: 'Settings', path: '/settings/system', icon: '⚙️' },
{ name: 'Tasks', path: '/tasks/backups', icon: '📋' },
{
name: 'Settings',
icon: '⚙️',
children: [
{ name: 'System', path: '/settings/system', icon: '⚙️' },
{ name: 'Account', path: '/settings/account', icon: '🛡️' },
]
},
{
name: 'Tasks',
icon: '📋',
children: [
{ name: 'Backups', path: '/tasks/backups', icon: '💾' },
{ name: 'Logs', path: '/tasks/logs', icon: '📝' },
]
},
]
return (
<div className="min-h-screen bg-gray-50 dark:bg-dark-bg flex transition-colors duration-200">
<div className="min-h-screen bg-light-bg dark:bg-dark-bg flex transition-colors duration-200">
{/* Mobile Header */}
<div className="lg:hidden fixed top-0 left-0 right-0 h-16 bg-white dark:bg-dark-sidebar border-b border-gray-200 dark:border-gray-800 flex items-center justify-between px-4 z-40">
<h1 className="text-lg font-bold text-gray-900 dark:text-white">CPM+</h1>
@@ -71,14 +85,49 @@ export default function Layout({ children }: LayoutProps) {
<div className="flex flex-col flex-1 px-4 mt-16 lg:mt-0">
<nav className="flex-1 space-y-1">
{navigation.map((item) => {
const isActive = location.pathname === item.path ||
(item.path.startsWith('/settings') && location.pathname.startsWith('/settings') && item.path === '/settings/system') ||
(item.path.startsWith('/tasks') && location.pathname.startsWith('/tasks'))
if (item.children) {
// Group Header
return (
<div key={item.name} className="pt-4 first:pt-0">
{!isCollapsed && (
<h3 className="px-4 text-xs font-semibold text-gray-500 uppercase tracking-wider mb-2">
{item.name}
</h3>
)}
{isCollapsed && (
<div className="h-px bg-gray-200 dark:bg-gray-700 my-2 mx-4" />
)}
<div className="space-y-1">
{item.children.map((child) => {
const isActive = location.pathname === child.path
return (
<Link
key={child.path}
to={child.path!}
onClick={() => setMobileSidebarOpen(false)}
className={`flex items-center gap-3 px-4 py-3 rounded-lg text-sm font-medium transition-colors ${
isActive
? 'bg-blue-100 text-blue-700 dark:bg-blue-active dark:text-white'
: 'text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-800 hover:text-gray-900 dark:hover:text-white'
} ${isCollapsed ? 'justify-center' : ''}`}
title={isCollapsed ? child.name : ''}
>
<span className="text-lg">{child.icon}</span>
{!isCollapsed && child.name}
</Link>
)
})}
</div>
</div>
)
}
const isActive = location.pathname === item.path
return (
<Link
key={item.path}
to={item.path}
to={item.path!}
onClick={() => setMobileSidebarOpen(false)}
className={`flex items-center gap-3 px-4 py-3 rounded-lg text-sm font-medium transition-colors ${
isActive
+18
View File
@@ -7,6 +7,8 @@ interface LogFiltersProps {
onSearchChange: (value: string) => void;
status: string;
onStatusChange: (value: string) => void;
level: string;
onLevelChange: (value: string) => void;
host: string;
onHostChange: (value: string) => void;
onRefresh: () => void;
@@ -19,6 +21,8 @@ export const LogFilters: React.FC<LogFiltersProps> = ({
onSearchChange,
status,
onStatusChange,
level,
onLevelChange,
host,
onHostChange,
onRefresh,
@@ -50,6 +54,20 @@ export const LogFilters: React.FC<LogFiltersProps> = ({
/>
</div>
<div className="w-full md:w-32">
<select
value={level}
onChange={(e) => onLevelChange(e.target.value)}
className="block w-full rounded-md border-gray-300 dark:border-gray-600 shadow-sm focus:border-blue-500 focus:ring-blue-500 sm:text-sm dark:bg-gray-700 dark:text-white"
>
<option value="">All Levels</option>
<option value="DEBUG">Debug</option>
<option value="INFO">Info</option>
<option value="WARN">Warn</option>
<option value="ERROR">Error</option>
</select>
</div>
<div className="w-full md:w-32">
<select
value={status}