File size: 2,848 Bytes
6a94706
b537c3b
7980609
b537c3b
 
 
96fe3dc
b537c3b
 
 
920d44a
b537c3b
96fe3dc
 
 
 
 
b100541
96fe3dc
 
 
 
 
920d44a
b537c3b
920d44a
 
6a94706
ddecc3d
6a94706
920d44a
 
ddecc3d
 
 
b100541
ddecc3d
 
 
 
 
6a94706
920d44a
6a94706
920d44a
6a94706
920d44a
 
b537c3b
 
 
 
 
 
6a94706
b537c3b
 
6a94706
b537c3b
 
6a94706
b537c3b
 
 
 
 
 
 
 
 
920d44a
7980609
920d44a
7980609
920d44a
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import gradio as gr
import pandas as pd

# Function to load the menu data from Excel
def load_menu():
    menu_file = "menu.xlsx"  # Make sure this file exists in the same directory
    try:
        return pd.read_excel(menu_file)
    except Exception as e:
        raise ValueError(f"Error loading menu file: {e}")

# Function to filter menu items based on preference
def filter_menu(preference):
    # Load menu data
    menu_data = load_menu()

    # Check for the required columns
    required_columns = ["Category", "Dish Name", "Price ($)", "Image URL", "Description"]
    for col in required_columns:
        if col not in menu_data.columns:
            raise ValueError(f"Missing column in Excel file: {col}")

    # Filter data based on preference
    if preference != "All":
        filtered_data = menu_data[menu_data["Category"].str.contains(preference, case=False, na=False)]
    else:
        filtered_data = menu_data

    # Generate HTML for the menu
    html_content = ""
    for _, item in filtered_data.iterrows():
        html_content += f"""
        <div style="display: flex; align-items: center; border: 1px solid #ddd; border-radius: 8px; padding: 15px; margin-bottom: 10px; box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.1);">
            <div style="flex: 1; margin-right: 15px;">
                <h3 style="margin: 0; font-size: 18px;">{item['Dish Name']}</h3>
                <p style="margin: 5px 0; font-size: 16px; color: #888;">${item['Price ($)']}</p>
                <p style="margin: 5px 0; font-size: 14px; color: #555;">{item['Description']}</p>
            </div>
            <div style="flex-shrink: 0; text-align: center;">
                <img src="{item['Image URL']}" alt="{item['Dish Name']}" style="width: 100px; height: 100px; border-radius: 8px; object-fit: cover; margin-bottom: 10px;">
                <button style="background-color: #28a745; color: white; border: none; padding: 8px 15px; font-size: 14px; border-radius: 5px; cursor: pointer;">Add</button>
            </div>
        </div>
        """
    return html_content

# Gradio app definition
def app():
    # Radio button for selecting preference
    selected_preference = gr.Radio(
        choices=["All", "Vegan", "Halal", "Guilt-Free"],
        value="All",
        label="Choose a Preference",
    )

    # Output area for menu items
    menu_output = gr.HTML(value=filter_menu("All"))

    # Set up Gradio interface
    selected_preference.change(filter_menu, inputs=[selected_preference], outputs=[menu_output])

    # Layout definition
    demo = gr.Interface(
        fn=None,
        inputs=[selected_preference],
        outputs=[menu_output],
        live=True,
        title="Dynamic Menu with Preferences",
        theme="default",
    )
    return demo

# Run the app
if __name__ == "__main__":
    demo = app()
    demo.launch()