AI-powered culinary assistant. Chat with a virtual Michelin-star chef, get personalized recipes, and elevate your cooking skills.
Live Demo: https://deep-chef.netlify.app/
DeepChef brings the expertise of a Michelin-starred chef, Auguste, directly to your kitchen. This web application leverages the power of AI to provide a personalized and interactive culinary experience. Create custom profiles, chat with Auguste, and receive recipe suggestions tailored to your specific needs and preferences, even using image recognition of your ingredients!
DeepChef is designed to be your all-in-one culinary companion. Here's how it works:
-
Create Personalized Profiles:
- Define your cooking skill level (from Beginner to Professional).
- Specify dietary restrictions (Vegetarian, Vegan, Gluten-Free, Keto, and more).
- List your available kitchen appliances (Oven, Stovetop, Microwave, Air Fryer, etc.).
- Add personal details about your cooking journey, favorite cuisines, or dietary goals.
data:image/s3,"s3://crabby-images/ab29c/ab29c7b5343bc5f858209bb172fd846ed54e3b28" alt="Screenshot 2025-02-17 at 14 21 06"
data:image/s3,"s3://crabby-images/0b4fb/0b4fb402b7489b2a479bc44fbe60d1c17d4f4354" alt="Screenshot 2025-02-17 at 14 22 34"
Example of creating a new profile, highlighting dietary restrictions and kitchen appliances.
data:image/s3,"s3://crabby-images/c8756/c8756da32f574441d12b6cd17cafd665f4efcc4a" alt="Screenshot 2025-02-17 at 14 23 55"
Managing multiple profiles, each with unique settings.
You can create multiple profiles, each with unique settings. This is perfect for managing different dietary needs or experimenting with various cooking styles.
-
Chat with Auguste:
- Engage in natural conversations with Auguste, your AI chef.
- Ask for cooking tips, recipe ideas, or general culinary advice.
- Auguste remembers your profile details and tailors responses accordingly.
- Conversation history is saved per profile, so you can easily refer back to previous interactions.
Example conversation with Auguste, demonstrating personalized responses.
-
Get Personalized Recipes:
- Tell Auguste what ingredients you have on hand, or upload an image of your food items!
- Auguste will analyze the image to identify the ingredients and then craft a detailed recipe, including:
- A clear title.
- A complete ingredient list with quantities.
- Step-by-step instructions, explaining why each step is important.
- Precise measurements and cooking times.
- Helpful tips and variations.
- Recipes are generated with your profile's cooking skill, dietary restrictions, and available appliances in mind.
data:image/s3,"s3://crabby-images/f5ecd/f5ecdcd2e52af44305d915f135cf36eab5f567cf" alt="Screenshot 2025-02-17 at 14 51 35"
data:image/s3,"s3://crabby-images/e9924/e99242fb7b5e39db17a1d0ace6ea6beda3f3b244" alt="Screenshot 2025-02-17 at 14 51 47"
Auguste providing a detailed and custom recipe, taking the user's profile into account.
DeepChef is built using a modern web development stack:
- Frontend: React, React Router, Framer Motion, Lucide React, Tailwind CSS, Vite
- Backend: Netlify Functions, Google Gemini API, Moondream API
- Deployment: Netlify
This section provides a high-level overview of the project's structure and includes illustrative code snippets. (Note: The full codebase is not publicly available.)
-
Frontend: The user interface is built with React, using a component-based architecture. State management is handled with React's built-in hooks and local storage for persisting user profiles and conversation history. Key components include
AIChatAssistant
,ProfileCreation
, andHomepage
. -
Backend: Netlify Functions handle API requests securely. These functions interact with the Google Gemini API for AI chat and recipe generation, and the Moondream API for image analysis.
Example: Image Analysis with Moondream (Netlify Function):
// netlify/functions/moondream-analysis.js exports.handler = async function (event) { try { const { imageBase64 } = JSON.parse(event.body); if (!imageBase64) { throw new Error("Image data is required"); } const moondreamKey = process.env.MOONDREAM_API_KEY; const response = await fetch("https://api.moondream.ai/v1/caption", { method: "POST", headers: { "Content-Type": "application/json", "X-Moondream-Auth": moondreamKey, }, body: JSON.stringify({ image_url: `data:image/jpeg;base64,${imageBase64}`, stream: false, }), }); if (!response.ok) { throw new Error(`Moondream API failed with status ${response.status}`); } const moondreamData = await response.json(); return { statusCode: 200, body: JSON.stringify({ caption: moondreamData.caption || "No caption available", }), }; } catch (error) { // ... error handling ... } };
This snippet shows how the
moondream-analysis
Netlify Function receives a base64-encoded image, sends it to the Moondream API for captioning, and returns the result.Example: AI Chat with Gemini (Netlify Function):
// netlify/functions/ai-chat.js (partial) exports.handler = async function (event) { try { const { messages, imageAnalysis, userProfile } = JSON.parse(event.body); const geminiKey = process.env.GEMINI_API_KEY; let profileContext = ''; if (userProfile) { // ... build profileContext string ... } const aiMessages = [ { role: "system", content: `You are Auguste, a Michelin-star chef ... ${profileContext} // ... rest of the system prompt ...`, }, ]; // ... add user messages and image analysis to aiMessages ... const geminiResponse = await retryRequest(async () => { // Using retry logic const response = await fetch( `https://generativelanguage.googleapis.com/v1beta/models/gemini-pro:generateContent?key=${geminiKey}`, { method: "POST", // ... headers and body ... } ); if (!response.ok) { throw new Error(`Gemini API failed with status ${response.status}`); } return response; }); const geminiData = await geminiResponse.json(); const responseText = geminiData.candidates?.[0]?.content?.parts?.[0]?.text || "No response content found"; return { statusCode: 200, body: JSON.stringify({ content: responseText, }), }; } catch (error) { // ... error handling ... } };
This snippet demonstrates how the ai-chat
function integrates user profiles, previous messages, and image analysis (from Moondream) into the prompt for the Gemini API. It also shows the use of a retryRequest
function (not shown here, but present in your code) to handle potential API rate limits.
Example: Profile Data Structure (React Component):
```javascript
//Simplified example from ProfileCreation.jsx or similar
const [formData, setFormData] = useState({
id: null,
name: "",
age: "",
dietaryRestrictions: [],
otherRestrictions: "",
cookingLevel: "",
appliances: [],
description: ""
});
```
This snippet illustrates the structure used to manage user profile data within the React application.
- User Profiles: User profile and conversation are stored using browser's local storage.
DeepChef is a project by Jordan Montée (AlikelDev) and Kamil Serrai (@Klima42) for Alikearn Studio.