Commit Graph

205 Commits

Author SHA1 Message Date
24b990ac62 feat: Implement Phase 4 - Application Architecture & Routing
Phase 4 establishes the core application structure with SvelteKit routing,
data loading, error handling, and state management.

## Routing & Data Loading
- Created root layout load function (+layout.ts) with app version and feature flags
- Implemented comprehensive error boundary (+error.svelte) with status-based messages
- Added page loaders for homepage, matches, players, and about routes
- Homepage loader fetches featured matches via API with error fallback
- Matches loader supports URL query parameters (map, player_id, limit)

## State Management (Svelte Stores)
- preferences.ts: User settings with localStorage persistence
  * Theme selection (cs2dark, cs2light, auto)
  * Favorite players tracking
  * Advanced stats toggle, date format preferences
- search.ts: Search state with recent searches (localStorage)
- toast.ts: Toast notification system with auto-dismiss
  * Success, error, warning, info types
  * Configurable duration and dismissibility

## UI Components
- Toast.svelte: Individual notification with Lucide icons
- ToastContainer.svelte: Fixed top-right toast display
- Integrated ToastContainer into root layout

## Fixes
- Fixed Svelte 5 deprecation warnings (removed <svelte:component> in runes mode)
- Updated homepage to use PageData from loader
- Added proper type safety across all load functions

## Testing
- Type check: 0 errors, 0 warnings
- Production build: Successful
- All Phase 4 core objectives completed

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 20:47:49 +01:00
d811efc394 feat: complete Phase 3 - Domain Modeling & Data Layer
Implements comprehensive type system, runtime validation, API client,
and testing infrastructure for CS2.WTF.

TypeScript Interfaces (src/lib/types/):
- Match.ts: Match, MatchPlayer, MatchListItem types
- Player.ts: Player, PlayerMeta, PlayerProfile types
- RoundStats.ts: Round economy and performance data
- Weapon.ts: Weapon statistics with hit groups (HitGroup, WeaponType enums)
- Message.ts: Chat messages with filtering support
- api.ts: API responses, errors, and APIException class
- Complete type safety with strict null checks

Zod Schemas (src/lib/schemas/):
- Runtime validation for all data models
- Schema parsers with safe/unsafe variants
- Special handling for backend typo (looses → losses)
- Share code validation regex
- CS2-specific validations (rank 0-30000, MR12 rounds)

API Client (src/lib/api/):
- client.ts: Axios-based HTTP client with error handling
  - Request cancellation support (AbortController)
  - Automatic retry logic for transient failures
  - Timeout handling (10s default)
  - Typed APIException errors
- players.ts: Player endpoints (profile, meta, track/untrack, search)
- matches.ts: Match endpoints (parse, details, weapons, rounds, chat, search)
- Zod validation on all API responses

MSW Mock Handlers (src/mocks/):
- fixtures.ts: Comprehensive mock data for testing
- handlers/players.ts: Mock player API endpoints
- handlers/matches.ts: Mock match API endpoints
- browser.ts: Browser MSW worker for development
- server.ts: Node MSW server for Vitest tests
- Realistic responses with delays and pagination
- Safe integer IDs to avoid precision loss

Configuration:
- .env.example: Complete environment variable documentation
- src/vite-env.d.ts: Vite environment type definitions
- All strict TypeScript checks passing (0 errors, 0 warnings)

Features:
- Cancellable requests for search (prevent race conditions)
- Data normalization (backend typo handling)
- Comprehensive error types (NetworkError, Timeout, etc.)
- Share code parsing and validation
- Pagination support for players and matches
- Mock data for offline development and testing

Build Status: ✓ Production build successful
Type Check: ✓ 0 errors, 0 warnings
Lint: ✓ All checks passed
Phase 3 Completion: 100%

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 20:31:20 +01:00
153c0e9f13 feat: implement CS2-inspired design system and UI components
This commit delivers a comprehensive design system and component library
inspired by Counter-Strike 2's tactical aesthetic.

Design System:
- Created docs/DESIGN.md with complete design language documentation
- CS2-inspired color palette: T-side orange (#d4a74a), CT-side blue (#5e98d9)
- Dark-first approach with tactical, data-dense layouts
- Typography scale, spacing system, and animation guidelines

Component Library:
- Button component: 4 variants (primary, secondary, ghost, danger), 3 sizes
- Badge component: 7 variants including team-specific badges
- Card component: 3 variants (default, elevated, interactive)
- Header component: Responsive navigation with mobile menu
- Footer component: Site-wide footer with organized link sections

Pages:
- Redesigned homepage with hero section, featured matches, features grid, CTA
- Created placeholder pages: /matches, /players, /about
- All pages follow CS2 aesthetic with proper component usage

Technical Fixes:
- Fixed Svelte 5 snippet syntax errors (removed incorrect render prop pattern)
- Fixed Card component accessibility (conditional button/div rendering)
- Removed invalid CSS border-border class from app.css
- Ensured zero TypeScript errors and warnings

Build Status: ✓ Verified with 0 errors, 0 warnings

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 20:07:05 +01:00
288438a953 feat: complete Phase 1 - Technical Foundations for CS2.WTF rewrite
Initialize SvelteKit project with complete modern web development stack:

## Core Framework
- SvelteKit 2.0 with Svelte 5 and TypeScript strict mode
- Vite 5 for blazing fast dev server and builds
- Node.js 20 standardized via .nvmrc

## Styling & Theming
- Tailwind CSS 3.4 with utility-first approach
- DaisyUI 4.0 with custom CS2 themes (cs2dark/cs2light)
- CS2-branded color palette (T-side orange, CT-side blue)
- PostCSS for CSS processing

## Code Quality & Tooling
- ESLint 8 with TypeScript + Svelte plugins
- Prettier 3 with Svelte + Tailwind plugins
- Stylelint 16 for CSS linting
- Husky 9 + lint-staged for pre-commit hooks
- TypeScript 5.3 with all strict flags enabled

## Testing Infrastructure
- Vitest 1.0 for unit/component tests with jsdom
- Playwright 1.40 for E2E tests (3 browsers)
- Testing Library for component testing
- MSW 2.0 for API mocking
- Coverage thresholds set to 80%

## Project Structure
- Organized src/ with lib/, routes/, mocks/, tests/
- Component directories: layout, ui, charts, match, player
- Path aliases configured: $lib, $components, $stores, $types, $api
- Separate test directories: unit, integration, e2e

## CI/CD & Deployment
- Updated Woodpecker CI pipeline with quality gates
- Pipeline steps: install → lint → type-check → test → build
- Deploy targets: master (prod), dev (staging), cs2-port (preview)

## Documentation
- Comprehensive README.md with setup guide
- API.md with complete backend documentation (12 endpoints)
- TODO.md updated with Phase 0 & 1 completion
- Environment variables template (.env.example)

## Development Experience
- Hot module reloading configured
- Dev server running on port 5173
- All npm scripts defined for dev, test, build workflows
- Pre-commit hooks prevent broken code commits

Project is now ready for feature development (Phase 2+).

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 19:54:35 +01:00
9ab7ee91ea refactor!: Clear out legacy code for rewrite. 2025-11-04 18:35:46 +01:00
36fbe8a685 updated source links 2023-03-01 21:55:06 +01:00
2a541196a4 switched to cookieless tracking 2022-12-07 06:50:03 +01:00
0739d3bf7b fixed OpenSans Variable usage in other pages 2022-11-22 17:14:09 +01:00
5279267c8e fixed variable font not displaying correctly 2022-11-19 16:17:56 +01:00
f65fc0a0ea fixed fonts; fixed relative url paths 2022-11-14 01:28:57 +01:00
befc14d894 updated core-js 2022-11-14 01:27:49 +01:00
3ca1dfe310 Version 1.0.8 (#72)
Reviewed-on: https://git.harting.dev/CSGOWTF/csgowtf/pulls/72
2022-08-17 12:44:15 +02:00
9c7834f443 set expiredate for cookies to infinity 2022-02-21 05:29:42 +01:00
3963f6decf fixed #69 2022-02-13 01:33:43 +01:00
9ff510a9f6 update to version 1.0.6 (package updates + translate function for match-chat) 2022-02-12 03:35:10 +01:00
3c43788494 some minor bugfixes with the background 2022-02-11 21:34:23 +01:00
fb0cdf5d8e fixed stuff on player match table 2022-02-04 19:38:04 +01:00
d9e4891510 fixed #65 2022-02-04 16:30:01 +01:00
f64844c132 adjusted width of text on home 2022-02-03 21:26:45 +01:00
79b3c9a2f7 updated info-table on home 2022-02-03 20:20:18 +01:00
ceaad77b35 updated nav-brand 2022-02-03 19:27:54 +01:00
979edda905 fixed bug with background image 2022-02-03 18:20:31 +01:00
18f9796365 updated css 2022-02-03 17:49:43 +01:00
ededd0b292 updated chat display 2022-02-03 17:24:30 +01:00
100b447633 updated cheater-display on chat 2022-02-03 16:59:22 +01:00
45ab9887cf added tick_rate + condition to display chat 2022-02-03 16:37:42 +01:00
4f27e8dd16 added vac icon to chat + changed chat url 2022-02-03 16:15:58 +01:00
38d4b7d961 updated broken icon in chat history 4 2022-02-03 15:39:05 +01:00
30f394c116 updated broken icon in chat history 3 2022-02-03 15:34:48 +01:00
f26324c866 updated broken icon in chat history 2 2022-02-03 15:32:56 +01:00
1c3ca5013a updated broken icon in chat history 2022-02-03 15:20:03 +01:00
d134d03fb7 fixed #41 2022-02-03 15:15:14 +01:00
7114ca2479 added Chat-History to matches 2022-02-03 14:55:22 +01:00
2b4b0d082c fixed match-route over-complication 2022-02-03 13:36:36 +01:00
378a5f807c fixed #59 2022-02-03 13:13:59 +01:00
9c2331846b fix-attempt 4 on issue 59 2022-02-03 13:10:36 +01:00
92fbe53008 fix-attempt 3 on issue 59 2022-02-03 13:03:35 +01:00
6c2da805f0 fix-attempt 2 on issue 59 2022-02-03 12:57:48 +01:00
6b0dceeac0 fix-attempt on issue 59 2022-02-03 12:53:35 +01:00
3bcb2d6090 fixed #58 2022-02-03 12:29:20 +01:00
28d31a865c updated api-call error-handling 2022-02-03 12:26:18 +01:00
c5d64fd196 added toUppercase for authcode 2022-02-02 22:23:41 +01:00
8a8a58fe88 updated info-modal 2022-02-02 22:11:57 +01:00
23bc01d46f fixed tracking api 2022-02-02 22:02:28 +01:00
b6369e56c0 updated match page to highlight winner green (even if match was surrendered) 2022-02-02 19:59:24 +01:00
12ea324367 moved images from assets to public 2022-02-02 19:48:07 +01:00
25b05e9b31 added info-modal + updated error handling 2022-02-02 19:18:00 +01:00
7fc45c1bb5 updated average team ranks 2022-02-02 12:31:09 +01:00
1916168ba1 updated cookie consent + fixed #57 2022-02-02 11:55:23 +01:00
f3ef7b65a8 updated api requests from try/catch to axios handling 2022-02-02 02:23:42 +01:00