Add recipes, images, AI photo ID, barcode scanning & ingredient matching

- Fuzzy ingredient matching for bar inventory against recipes
- AI photo identification API for bottles/labels (drink + bar context)
- Barcode scanner with photo toggle for My Bar
- Barcode scan + photo ID buttons on Add Drink form
- Auto-pull product images from Open Food Facts barcode lookup
- Recipes section on drink detail pages with bar availability
- Dedicated Recipes page in sidebar navigation
- Bar item image support (schema, upload, display)
- Drink detail image upload component
- MinIO image proxy through Next.js rewrites (fixes broken image links)
- Improved category mapping (energy drinks → Mixers, not Spirits)
- Re-process saved recipe ingredients against current bar inventory

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
JP Scott
2026-03-04 22:26:17 -07:00
parent 2ac2c4b2d4
commit dc1ad4d0c0
36 changed files with 1892 additions and 144 deletions

View File

@@ -0,0 +1,22 @@
"use client"
import { RecipeCard } from "@/components/bartender/recipe-card"
import type { RecipeCardData } from "@/components/bartender/recipe-card"
interface DrinkRecipesListProps {
recipes: RecipeCardData[]
}
export function DrinkRecipesList({ recipes }: DrinkRecipesListProps) {
return (
<div className="space-y-4">
{recipes.map((recipe) => (
<RecipeCard
key={recipe.id}
recipe={recipe}
saved
/>
))}
</div>
)
}