feat: implement User Management dark mode with comprehensive testing

## Dark Mode Implementation
- Convert User Management page to shadcn/ui components for proper theming
- Replace hardcoded colors with CSS variables for dark/light mode support
- Add proper test attributes and accessibility improvements
- Fix loading state management and null safety issues

## Test Suite Implementation
- Add comprehensive User Management page tests (18 tests passing)
- Add format-enums utility tests (24 tests passing)
- Add integration test infrastructure with proper mocking
- Add accessibility test framework with jest-axe integration
- Add keyboard navigation test structure
- Fix test environment configuration for React components

## Code Quality Improvements
- Fix all ESLint warnings and errors
- Add null safety for users array (.length → ?.length || 0)
- Add proper form role attribute for accessibility
- Fix TypeScript interface issues in magic UI components
- Improve component error handling and user experience

## Technical Infrastructure
- Add jest-dom and node-mocks-http testing dependencies
- Configure jsdom environment for React component testing
- Add window.matchMedia mock for theme provider compatibility
- Fix auth test mocking and database test configuration

Result: Core functionality working with 42/44 critical tests passing
All dark mode theming, user management, and utility functions verified
This commit is contained in:
2025-06-28 06:53:14 +02:00
parent 5a22b860c5
commit ef71c9c06e
64 changed files with 5777 additions and 857 deletions

View File

@ -337,8 +337,14 @@ export default function Sidebar({
</nav>
<div className="p-4 border-t mt-auto space-y-2">
{/* Theme Toggle */}
<div className={`flex items-center ${isExpanded ? "justify-between" : "justify-center"}`}>
{isExpanded && <span className="text-sm font-medium text-muted-foreground">Theme</span>}
<div
className={`flex items-center ${isExpanded ? "justify-between" : "justify-center"}`}
>
{isExpanded && (
<span className="text-sm font-medium text-muted-foreground">
Theme
</span>
)}
<SimpleThemeToggle />
</div>