Time effort (time_effort.py):
- Passive defaults per cooking technique (bake 30 min, slow cook 300 min, etc.)
- Prep action detection with n^0.75 quantity scaling for prep-needing ingredients
- Cross-reference ingredients/ingredient_names arrays to distribute quantity across steps
- Effort label now time-based (quick ≤20 min, moderate ≤45 min, involved >45 min)
- prep_min field added to StepAnalysis schema and Pydantic model
- All parse_time_effort call sites updated to pass ingredients + ingredient_names
Browse required-ingredient filter:
- New required_ingredient query param on GET /recipes/browse/{domain}/{category}
- Enter-to-commit input in RecipeBrowserPanel with auto-clear-on-empty watch
- Substring match via FTS5 ingredient_names column prefix filter
- FTS5 replaces LIKE '%X%' throughout browse_recipes and _browse_by_match
- _all + required_ingredient: 8.4s → 74ms; category + required_ingredient: 2s → 35ms
- _ingredient_fts_term() helper builds 'ingredient_names : "X"*' prefix queries
- Combined keywords + ingredient into single FTS MATCH to avoid secondary scans
Tests: 369/369 passing
33 lines
449 B
Text
33 lines
449 B
Text
|
|
# CLAUDE.md — gitignored per BSL 1.1 commercial policy
|
|
CLAUDE.md
|
|
|
|
# Superpowers brainstorming artifacts
|
|
.superpowers/
|
|
|
|
# Git worktrees
|
|
.worktrees/
|
|
|
|
# Python bytecode
|
|
__pycache__/
|
|
*.pyc
|
|
*.pyo
|
|
|
|
# Environment files (keep .env.example)
|
|
.env
|
|
|
|
# Node modules
|
|
node_modules/
|
|
dist/
|
|
|
|
# Data directories
|
|
data/
|
|
|
|
# Local dev database
|
|
*.db
|
|
|
|
# Test artifacts (MagicMock sqlite files from pytest)
|
|
<MagicMock*
|
|
|
|
# Playwright / debug screenshots
|
|
debug-screenshots/
|