system-prompts-and-models-o.../web/lib/store.ts
Claude 9d5ee88ea3
feat: Add modern Next.js 15 web interface with React 19
This commit adds a complete, production-ready web application for browsing
and exploring AI tool system prompts. The interface provides an intuitive,
responsive, and feature-rich experience for discovering AI tools.

## Web Application Features

**Core Functionality:**
- 🔍 Advanced search with real-time filtering
- 📊 Interactive statistics dashboard with visualizations
- 🔄 Side-by-side comparison of up to 4 tools
-  Favorites system with local persistence
- 📱 Fully responsive mobile-first design
- 🎨 Dark/light mode with system preference detection
-  Optimized performance with Next.js Server Components

**Pages:**
- Home: Hero section, features showcase, featured tools
- Browse: Advanced filtering, grid/list views, category filters
- Stats: Comprehensive analytics and visualizations
- Compare: Side-by-side tool comparison
- Tool Detail: In-depth tool information
- About: Project information and tech stack

**Components:**
- Responsive navbar with mobile menu
- Tool cards with interactive actions
- Reusable UI components (Button, Card, Badge, Input)
- Footer with quick links and stats
- Theme provider for dark mode
- Loading and error states

## Technical Stack

**Framework & Libraries:**
- Next.js 15 with App Router
- React 19.0 with Server Components
- TypeScript 5.6 for type safety
- Tailwind CSS for styling
- Zustand for state management
- next-themes for theme switching
- Lucide React for icons

**Features:**
- Server-side rendering (SSR)
- Static site generation (SSG) for tool pages
- Optimized bundle with automatic code splitting
- SEO-friendly with metadata API
- Accessibility best practices

## Project Structure

web/
├── app/                   # Next.js pages
├── components/            # React components
├── lib/                   # Utilities and data
├── data/                  # Static data (index.json)
├── setup.sh              # Setup script
└── README.md             # Documentation

## Developer Experience

- TypeScript for type safety
- ESLint for code quality
- Hot module replacement
- Fast refresh
- Comprehensive documentation
- Setup script for quick start

## Updated Documentation

- Enhanced main README with web interface section
- Created comprehensive web/README.md
- Updated roadmap to mark completed features
- Added Quick Start guide for web app

## Stats

- 33 new files created
- ~3,500 lines of TypeScript/TSX
- Full responsive design (mobile, tablet, desktop)
- Production-ready with build optimizations

Users can now explore 32+ AI tools through an intuitive web interface
instead of just command-line tools.

Version: 2.0.0
2025-11-15 02:20:46 +00:00

90 lines
2.4 KiB
TypeScript

import { create } from 'zustand'
import { persist } from 'zustand/middleware'
import { AITool, FilterState } from './types'
interface AppState {
// Favorites
favorites: string[]
addFavorite: (toolDirectory: string) => void
removeFavorite: (toolDirectory: string) => void
isFavorite: (toolDirectory: string) => boolean
// Comparison
comparison: string[]
addToComparison: (toolDirectory: string) => void
removeFromComparison: (toolDirectory: string) => void
clearComparison: () => void
isInComparison: (toolDirectory: string) => boolean
// Filters
filters: FilterState
setFilters: (filters: Partial<FilterState>) => void
resetFilters: () => void
// View preferences
viewMode: 'grid' | 'list'
setViewMode: (mode: 'grid' | 'list') => void
}
const defaultFilters: FilterState = {
search: '',
categories: [],
types: [],
companies: [],
models: [],
sortBy: 'name',
sortOrder: 'asc',
}
export const useAppStore = create<AppState>()(
persist(
(set, get) => ({
// Favorites
favorites: [],
addFavorite: (toolDirectory) =>
set((state) => ({
favorites: [...state.favorites, toolDirectory],
})),
removeFavorite: (toolDirectory) =>
set((state) => ({
favorites: state.favorites.filter((dir) => dir !== toolDirectory),
})),
isFavorite: (toolDirectory) => get().favorites.includes(toolDirectory),
// Comparison
comparison: [],
addToComparison: (toolDirectory) =>
set((state) => {
if (state.comparison.length >= 4) return state
return { comparison: [...state.comparison, toolDirectory] }
}),
removeFromComparison: (toolDirectory) =>
set((state) => ({
comparison: state.comparison.filter((dir) => dir !== toolDirectory),
})),
clearComparison: () => set({ comparison: [] }),
isInComparison: (toolDirectory) =>
get().comparison.includes(toolDirectory),
// Filters
filters: defaultFilters,
setFilters: (filters) =>
set((state) => ({
filters: { ...state.filters, ...filters },
})),
resetFilters: () => set({ filters: defaultFilters }),
// View preferences
viewMode: 'grid',
setViewMode: (mode) => set({ viewMode: mode }),
}),
{
name: 'ai-prompts-storage',
partialize: (state) => ({
favorites: state.favorites,
viewMode: state.viewMode,
}),
}
)
)