Files
budget-app/CLAUDE.md
Christian Hood 8a9844cf72 Add paycheck-centric main view
Two-column monthly view showing bills, amounts, paid status,
and remaining balance per paycheck. Month navigation included.
Also adds PATCH /api/paycheck-bills/:id/paid endpoint.

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-19 19:09:51 -04:00

53 lines
1.7 KiB
Markdown

# CLAUDE.md
This file provides guidance to Claude Code (claude.ai/code) when working with code in this repository.
## Agent Workflow Rules
- **Commit after every task**: When a task is complete, stage all changed files and create a git commit before marking the task done.
- **Keep documentation current**: Update `CLAUDE.md` with any new commands, architecture details, or setup steps introduced by your task. Update `PRD.md` only if scope/design decisions changed.
- **Mark tasks in td**: `td start <id>` when beginning, `td close <id>` when done.
## Task Management
This project uses `td` (a local CLI) for task tracking. At the start of each session:
```bash
td usage --new-session # required at conversation start or after /clear
td usage -q # quick check for subsequent reads
```
Optional session labeling:
```bash
td session "name" # label the current session
td session --new # force a new session in the same terminal context
```
Task state is stored in `.todos/issues.db` (SQLite).
## Development
**Run production stack (Docker):**
```bash
docker compose up
```
**Run development stack with live reload (Docker):**
```bash
docker compose -f docker-compose.yml -f docker-compose.dev.yml up
```
**Frontend only (Vite dev server):**
```bash
cd client && npm install && npm run dev
```
**Backend only (nodemon):**
```bash
cd server && npm install && npm run dev
```
## Application Structure
The default route `/` renders the paycheck-centric main view (`client/src/pages/PaycheckView.jsx`). It shows the current month's two paychecks side-by-side with bills, paid status, one-time expenses, and remaining balance. Month navigation (prev/next) fetches data via `GET /api/paychecks?year=&month=`.