npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@kunwarshah/claudex

v1.2.1

Published

Professional conversation viewer and analysis tool for Claude Code. Search, analyze, and export your AI conversations with enterprise-grade full-text search and multi-platform support.

Downloads

236

Readme

Claudex

Professional conversation viewer and analysis tool for Claude Code

Category: Development Tools · Conversation Analysis · Usage Monitoring

Claudex is a full-stack web application designed for developers, QA engineers, and researchers who need to inspect, search, and analyze Claude Code conversation histories. Built with React and Fastify, it provides enterprise-grade full-text search using SQLite FTS5, universal template support for all Claude Code versions, and comprehensive analytics dashboards.

Version License: MIT Documentation Discussions

📚 Documentation | 💬 Discussions | 🐛 Issues


🆕 What's New

Version 1.1.1 (October 31, 2025)

  • 🐛 Fixed Critical Bug: Resolved duplicate message IDs causing intermittent empty session displays (PR #7)
    • Line-based unique ID generation ensures all messages render correctly
    • Eliminates React duplicate key warnings
    • Handles Claude Code's multi-part message format seamlessly
  • 📄 Added LICENSE: MIT License file for improved GitHub API discoverability (PR #8)
  • 🚀 Quick Start Script: One-command installation leveraging existing system checker

Version 1.1.0 (October 27, 2025)

  • 🎯 Smart Title Extraction: Automatically extracts meaningful session titles from conversation content
  • 📊 Tremor Analytics Dashboard: Re-enabled with proper Tailwind-based color system and multi-scale visualizations
  • 🐳 Docker Multi-Platform: Support for amd64 and arm64 with optimized ~200MB images
  • ⚡ Performance: 121x faster async search index rebuild
  • 🔧 System Checker: Auto-fix capabilities for common setup issues (npm run check:fix)

View full changelog | Troubleshooting guide


📸 Screenshots

Conversation View

Full-Text Search

✨ Features

  • Auto Project Discovery: Automatically scans ~/.claude/projects directory to discover all available conversations across multiple projects
  • Full-Text Search: Enterprise-grade SQLite FTS5 search engine with advanced filtering by project, session, role, date range, and content highlighting
  • Universal Template Support: Intelligent template detection and parsing for all Claude Code versions (V1.x, V2-mixed, V2.0+) with automatic format detection
  • Smart Content Rendering: Syntax-highlighted code blocks, markdown rendering, diff visualization, JSON formatting, and tool usage tracking
  • Session Analytics: Comprehensive analytics dashboard with message distribution charts, file operation tracking, and conversation statistics using Tremor React
  • Export Options: Export conversations to JSON (structured data), HTML (readable format), or plain TXT for archival and sharing
  • Modern UI: Responsive React interface with fixed header/footer navigation, infinite scroll, and optimized for developer workflows
  • Hot Reload: Development mode with automatic restart on code changes for rapid iteration

🚀 Quick Start

Prerequisites

  • Node.js 18+ and npm
  • Claude Code installed with conversation history in ~/.claude/projects

Installation

Option 1: npm (Recommended - Coming Soon)

Note: npm package will be available after Phase B.2 completion

# Global installation
npm install -g @kunwarshah/claudex

# Then run anywhere:
claudex

# Or use without installing (npx):
npx @kunwarshah/claudex

Option 2: From Source

  1. Clone the repository:
git clone https://github.com/kunwar-shah/claudex.git
cd claudex
  1. Run system check (optional but recommended):
npm run check

This validates your environment and catches common setup issues.

  1. Install dependencies (or use auto-fix):
# Option 1: Manual installation
npm install
cd server && npm install && cd ..
cd client && npm install && cd ..

# Option 2: Auto-fix (installs deps + creates .env)
npm run check:fix
  1. Configure environment (if not using auto-fix):
cd server
cp .env.example .env
# Edit .env if needed (default: PROJECT_ROOT=~/.claude/projects)
cd ..
  1. Start the application:
# Automatically runs system check, then starts servers
npm run dev
  1. Open your browser: http://localhost:3000

The backend API runs on http://localhost:3400

System Checker

Claudex includes a comprehensive system checker that validates your environment:

# Quick check
npm run check

# Detailed output
npm run check:verbose

# Auto-fix common issues
npm run check:fix

# JSON output (for CI/CD)
npm run check:json

What it checks:

  • ✅ Node.js & npm versions
  • ✅ PROJECT_ROOT path & permissions
  • ✅ Port availability (3000, 3400)
  • ✅ Dependencies installation
  • ✅ Claude Code data (projects, sessions)
  • ✅ JSONL file validity
  • ✅ Database permissions
  • ✅ Search index status

Global CLI Installation (Optional)

Install globally to use claudex command anywhere:

./install.sh

# Then run from anywhere:
claudex

🔧 Configuration

Server Configuration (.env)

# Path to Claude Code projects directory
# Supports ~ expansion (e.g., ~/.claude/projects)
PROJECT_ROOT=~/.claude/projects

# Server port
PORT=3400

# Environment
NODE_ENV=development

Default Ports

  • Frontend: http://localhost:3000 (Vite dev server)
  • Backend: http://localhost:3400 (Fastify API)
  • Frontend build: Uses port 3400 (served by backend in production)

📂 Project Structure

claudex/
├── server/                    # Backend (Node.js + Fastify)
│   ├── src/
│   │   ├── parsers/          # Template detection & message parsing
│   │   │   ├── templateDetector.js    # V1/V2/V3 template detection
│   │   │   └── messageParser.js       # Universal message parser
│   │   ├── services/         # Core business logic
│   │   │   ├── fileScanner.js        # Project/session discovery
│   │   │   ├── sessionParser.js      # Full session parsing
│   │   │   ├── searchDatabase.js     # SQLite FTS5 search
│   │   │   └── searchIndexer.js      # Search index builder
│   │   ├── routes/           # API endpoints
│   │   │   ├── projects.js           # Project/session routes
│   │   │   ├── search.js             # Search routes
│   │   │   └── export.js             # Export routes
│   │   ├── utils/            # Helper utilities
│   │   │   └── pathHelper.js         # Path expansion (~/ support)
│   │   └── server.js         # Main server
│   ├── data/                 # SQLite database (auto-created)
│   ├── .env.example          # Environment template
│   └── package.json
├── client/                   # Frontend (React + Vite)
│   ├── src/
│   │   ├── components/       # React components
│   │   │   ├── ProjectSelector.jsx
│   │   │   ├── SessionList.jsx
│   │   │   ├── ConversationThread.jsx
│   │   │   ├── MessageBubble.jsx
│   │   │   ├── ClaudeMessageRenderer.jsx
│   │   │   └── SearchPage.jsx
│   │   ├── services/         # API client
│   │   │   └── api.js
│   │   └── App.jsx           # Main app
│   └── package.json
├── bin/                      # CLI entry point
├── test-search.sh           # Search API testing script
├── install.sh               # Global CLI installer
├── SETUP.md                 # Detailed setup guide
├── README.md                # This file
└── package.json             # Root package (CLI + concurrently)

🎯 Supported Claude Code Formats

The viewer automatically detects and parses all Claude Code conversation formats:

V3 Template (Universal - Recommended)

  • Claude Code v2.0+: New format with role field directly
  • Claude Code v1.x: Original format with type field
  • Edge cases: Mixed formats and migration states
  • New message types: file-history-snapshot support
  • Role mapping: All system messages → assistant (binary user/assistant classification)

Legacy Templates (Auto-detected)

  • V2-Mixed: Transition format between V1 and V2
  • V1: Original Claude Code format

The template detector uses a waterfall detection strategy, automatically selecting the best parser for your conversation files.

🔍 Search System

Building the Search Index

The search index needs to be built before searching:

# Option 1: Via API
curl -X POST http://localhost:3400/api/search/index/build

# Option 2: Via test script
./test-search.sh

# Option 3: Via UI (Search page → "Rebuild Index" button)

When to Rebuild Index

Rebuild the search index when:

  • First time setup
  • After template changes
  • When new conversations are added
  • If search results seem outdated

Search API Examples

# Basic search
curl -X POST http://localhost:3400/api/search \
  -H "Content-Type: application/json" \
  -d '{"q": "migration", "limit": 10}'

# Search with filters
curl -X POST http://localhost:3400/api/search \
  -H "Content-Type: application/json" \
  -d '{
    "q": "database",
    "projectId": "my-project",
    "role": "user",
    "limit": 20,
    "offset": 0
  }'

# Check index status
curl http://localhost:3400/api/search/index/status

📡 API Endpoints

Projects & Sessions

| Endpoint | Method | Description | |----------|--------|-------------| | /api/projects | GET | List all projects | | /api/projects/:id/sessions | GET | Get sessions for project | | /api/projects/:id/sessions/:sessionId | GET | Get full session with messages |

Search

| Endpoint | Method | Description | |----------|--------|-------------| | /api/search | POST | Search conversations (FTS5) | | /api/search/index/build | POST | Build/rebuild search index | | /api/search/index/status | GET | Get index statistics | | /api/search/index/clear | POST | Clear search index |

Export

| Endpoint | Method | Description | |----------|--------|-------------| | /api/export/session/:projectId/:sessionId?format=json | GET | Export as JSON | | /api/export/session/:projectId/:sessionId?format=html | GET | Export as HTML | | /api/export/session/:projectId/:sessionId?format=txt | GET | Export as TXT |

Health

| Endpoint | Method | Description | |----------|--------|-------------| | /api/health | GET | Health check + system info |

🛠️ Development

Development Mode

# Run both frontend + backend with hot reload
npm run dev

# Or run separately:
# Terminal 1 - Backend (auto-restarts on changes)
cd server && npm run dev

# Terminal 2 - Frontend (hot module replacement)
cd client && npm run dev

Testing the Search System

# Run comprehensive search tests
./test-search.sh

This script will:

  1. Check server health
  2. Get index status
  3. Build/rebuild index
  4. Run test searches with various filters
  5. Display results

Adding New Templates

  1. Update Template Detector (server/src/parsers/templateDetector.js):
'my-template': {
  name: 'My Template Name',
  detect: (samples) => {
    return samples.some(s => s.myUniqueField !== undefined);
  },
  parser: 'my-template'
}
  1. Add Parser Method (server/src/parsers/messageParser.js):
parseMyTemplate(rawMessage) {
  return {
    id: rawMessage.id || this.generateId(),
    role: rawMessage.myRole === 'user' ? 'user' : 'assistant',
    content: rawMessage.myContent || '',
    timestamp: rawMessage.myTimestamp,
    // ... other fields
  };
}
  1. Rebuild Search Index: The new template will be automatically detected and used.

📝 Scripts Reference

Claudex Directory

  • npm run dev - Run frontend + backend concurrently (with pre-check)
  • npm start - Run frontend + backend (production mode)
  • npm run check - Run system health check
  • npm run check:verbose - Run detailed system check
  • npm run check:fix - Auto-fix common setup issues
  • npm run check:json - JSON output for CI/CD
  • ./install.sh - Install as global CLI command
  • ./test-search.sh - Test search API endpoints

Server Directory

  • npm run dev - Run with nodemon (auto-restart)
  • npm start - Run in production mode

Client Directory

  • npm run dev - Vite dev server (http://localhost:3000)
  • npm run build - Build for production
  • npm run preview - Preview production build

🐛 Troubleshooting

Quick Diagnosis

Run the system checker first to identify issues:

npm run check:verbose

This will check all common problems and provide actionable suggestions.

Common Issues

"No messages found" Despite Messages Existing

Fixed in v1.1.1 - If you see intermittent empty sessions or duplicate key warnings:

# Update to latest version
cd claude-viewer
git pull origin main
npm install && cd server && npm install && cd ../client && npm install && cd ..
npm run dev

See detailed troubleshooting guide for more information.

No Projects Found

# Check what the system sees
npm run check

# Verify path
cat server/.env | grep PROJECT_ROOT
  • Verify PROJECT_ROOT in .env points to ~/.claude/projects
  • Check that Claude Code has created conversation files
  • Run npm run check:fix to auto-create missing directories

Search Not Working

# Quick fix via UI
# Visit http://localhost:3000/search → Click "Rebuild Index"

# Or via command line
curl -X POST http://localhost:3400/api/search/index/build

Port Conflicts

# System checker will detect port conflicts
npm run check

# Auto-detected ports in use show PID
# Kill process: kill <PID>
# Or change PORT in server/.env

Permission Errors

# Check permissions
npm run check:verbose

# Fix permissions
chmod +r ~/.claude/projects
chmod +w claude-viewer/server/data

Dependencies Issues

# Auto-install all dependencies
npm run check:fix

🚢 Production Deployment

Using Docker (Recommended)

Claudex includes production-ready Docker configuration with multi-stage builds for optimal image size.

Quick Start with Docker

# Build and start with docker-compose
docker-compose up -d

# View logs
docker-compose logs -f

# Stop
docker-compose down

Access at: http://localhost:3400

Docker Configuration

The default docker-compose.yml mounts your Claude projects directory as read-only:

volumes:
  # Adjust path to match your system
  - ~/.claude/projects:/root/.claude/projects:ro

Common path configurations:

# Linux/macOS
~/.claude/projects:/root/.claude/projects:ro

# Windows (WSL2)
/mnt/c/Users/YourName/.claude/projects:/root/.claude/projects:ro

# Custom path
/path/to/your/projects:/root/.claude/projects:ro

Docker Commands

# Build image manually
docker build -t claudex:latest .

# Run container manually
docker run -d \
  -p 3400:3400 \
  -v ~/.claude/projects:/root/.claude/projects:ro \
  -v claudex-data:/app/data \
  --name claudex-web \
  claudex:latest

# Check health
docker ps  # Check STATUS column for "healthy"

# View logs
docker logs claudex-web -f

# Stop and remove
docker stop claudex-web && docker rm claudex-web

Docker Features

  • Multi-stage build: Optimized image size (~200MB)
  • Non-root user: Runs as nodejs user for security
  • Health checks: Automatic health monitoring
  • Persistent volumes: Stores search index and logs
  • Read-only mounts: Claude projects mounted read-only for safety
  • Log rotation: JSON logs with 10MB max size, 3 file rotation

Docker Environment Variables

# Override in docker-compose.yml or docker run
-e PORT=3400                           # Server port
-e HOST=0.0.0.0                        # Bind address
-e NODE_ENV=production                 # Environment
-e PROJECT_ROOT=/root/.claude/projects # Claude projects path

Manual Production Build

For non-Docker deployments:

# 1. Install dependencies
npm run install-deps

# 2. Build client
npm run build

# 3. Start server (serves built client)
cd server && NODE_ENV=production npm start

Access at: http://localhost:3400

📋 Roadmap

  • [x] SQLite FTS5 full-text search
  • [x] Universal template support (V1/V2/V3)
  • [x] Export to JSON/HTML/TXT
  • [x] Path portability with ~/ support
  • [x] Hot reload development mode
  • [x] Docker deployment (v1.1.0)
  • [x] Conversation analytics dashboard (v1.1.0)
  • [ ] WebSocket live updates
  • [ ] Authentication for multi-user
  • [ ] Plugin system for custom parsers
  • [ ] Diff viewer for file changes

📄 License

MIT License - see LICENSE file for details.

🤝 Contributing

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Commit changes: git commit -m 'Add amazing feature'
  4. Push to branch: git push origin feature/amazing-feature
  5. Open a Pull Request

📚 Additional Documentation

  • SETUP.md - Detailed setup and configuration guide
  • INSTALL.md - Legacy installation instructions

💡 Tips

  • Use the search page to find conversations across all projects
  • Export conversations to share with team members
  • Rebuild search index after adding new conversations
  • Check /api/health endpoint to verify system status
  • Use npm run dev for the best development experience with hot reload