File size: 2,144 Bytes
e7abd9e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# Frontend - Open LLM Leaderboard πŸ†

React interface for exploring and comparing open-source language models.

## πŸ— Architecture

```mermaid
flowchart TD
    Client(["User Browser"]) --> Components["React Components"]

    subgraph Frontend
        Components --> Context["Context Layer<br>β€’ LeaderboardContext<br>β€’ Global State"]

        API["API Layer<br>β€’ /api/leaderboard/formatted<br>β€’ TanStack Query"] --> |Data Feed| Context

        Context --> Hooks["Hooks Layer<br>β€’ Data Processing<br>β€’ Filtering<br>β€’ Caching"]

        Hooks --> Features["Features<br>β€’ Table Management<br>β€’ Search & Filters<br>β€’ Display Options"]
        Features --> Cache["Cache Layer<br>β€’ LocalStorage<br>β€’ URL State"]
    end

    API --> Backend["Backend Server"]

    style Backend fill:#f96,stroke:#333,stroke-width:2px
```

## ✨ Core Features

- πŸ” **Search & Filters**: Real-time filtering, regex search, advanced filters
- πŸ“Š **Data Visualization**: Interactive table, customizable columns, sorting
- πŸ”„ **State Management**: URL sync, client-side caching (5min TTL)
- πŸ“± **Responsive Design**: Mobile-friendly, dark/light themes

## πŸ›  Tech Stack

- React 18 + Material-UI
- TanStack Query & Table
- React Router v6

## πŸ“ Project Structure

```
src/
β”œβ”€β”€ pages/
β”‚   └── LeaderboardPage/
β”‚       β”œβ”€β”€ components/      # UI Components
β”‚       β”œβ”€β”€ context/        # Global State
β”‚       └── hooks/          # Data Processing
β”œβ”€β”€ components/             # Shared Components
└── utils/                 # Helper Functions
```

## πŸš€ Development

```bash
# Install dependencies
npm install

# Start development server
npm start

# Production build
npm run build
```

## πŸ”§ Environment Variables

```env
# API Configuration
REACT_APP_API_URL=http://localhost:8000
REACT_APP_CACHE_DURATION=300000  # 5 minutes
```

## πŸ”„ Data Flow

1. API fetches leaderboard data from backend
2. Context stores and manages global state
3. Hooks handle data processing and filtering
4. Components render based on processed data
5. Cache maintains user preferences and URL state