File size: 8,639 Bytes
ba4dd53
 
 
9acada1
ba4dd53
92b51ea
ba4dd53
92b51ea
ba4dd53
 
 
92b51ea
37e70db
92b51ea
ba4dd53
92b51ea
 
0f06d66
 
 
 
 
 
 
 
 
92b51ea
37e70db
0f06d66
37e70db
3c97bed
 
 
 
 
807b0c3
3c97bed
 
 
807b0c3
37e70db
 
 
 
92b51ea
37e70db
3c97bed
0f06d66
118d5fd
92b51ea
 
0d58d8b
 
92b51ea
4b578a2
92b51ea
 
6b86d43
 
3c97bed
92b51ea
a8ea6f9
b718f7e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a8ea6f9
b718f7e
 
 
 
 
 
 
 
 
 
 
0c48657
b718f7e
 
 
 
 
 
 
 
 
 
0f06d66
b718f7e
 
 
0f06d66
3c97bed
 
 
 
 
0f06d66
b718f7e
0f06d66
3c97bed
0f06d66
b718f7e
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
0f06d66
 
4b578a2
92b51ea
 
 
118d5fd
3c97bed
 
 
7980609
37e70db
7980609
92b51ea
7980609
92b51ea
 
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
import gradio as gr
import pandas as pd

# Function to load the menu data
def load_menu():
    menu_file = "menu.xlsx"  # Ensure 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()

    # Define filter conditions
    if preference == "Halal/Non-Veg":
        filtered_data = menu_data[menu_data["Ingredients"].str.contains("Chicken|Mutton|Fish|Prawns|Goat", case=False, na=False)]
    elif preference == "Vegetarian":
        filtered_data = menu_data[~menu_data["Ingredients"].str.contains("Chicken|Mutton|Fish|Prawns|Goat", case=False, na=False)]
    elif preference == "Guilt-Free":
        filtered_data = menu_data[menu_data["Description"].str.contains(r"Fat: ([0-9]|10)g", case=False, na=False)]
    else:  # Default to "All"
        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;" onclick="openModal('{item['Dish Name']}', '{item['Image URL']}', '{item['Description']}', '{item['Price ($)']}')">Add</button>
            </div>
        </div>
        """
    return html_content

# Gradio app definition
def app():
    with gr.Blocks() as demo:
        gr.Markdown("## Dynamic Menu with Preferences")

        # Radio button for selecting preference
        selected_preference = gr.Radio(
            choices=["All", "Vegetarian", "Halal/Non-Veg", "Guilt-Free"],
            value="All",
            label="Choose a Preference",
        )

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

        # Modal window
        modal_window = gr.HTML("""
        <div id="modal" style="display: none; position: fixed; top: 40%; left: 50%; transform: translate(-50%, -40%); width: 50%; background: white; border-radius: 8px; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); padding: 20px; z-index: 1000;">
            <div style="text-align: right;">
                <button onclick="closeModal()" style="background: none; border: none; font-size: 18px; cursor: pointer;">&times;</button>
            </div>
            <img id="modal-image" style="width: 100%; height: auto; border-radius: 8px; margin-bottom: 20px;" />
            <h2 id="modal-name"></h2>
            <p id="modal-description"></p>
            <p id="modal-price"></p>

            <!-- Spice Levels -->
            <label for="spice-level">Choose a Spice Level (Required):</label>
            <div id="spice-level-options" style="display: flex; flex-wrap: wrap; gap: 10px; margin: 10px 0;">
                <label><input type="radio" name="spice-level" value="American Mild" required /> American Mild</label>
                <label><input type="radio" name="spice-level" value="American Medium" required /> American Medium</label>
                <label><input type="radio" name="spice-level" value="American Spicy" required /> American Spicy</label>
                <label><input type="radio" name="spice-level" value="Indian Mild" required /> Indian Mild</label>
                <label><input type="radio" name="spice-level" value="Indian Medium" required /> Indian Medium</label>
                <label><input type="radio" name="spice-level" value="Indian Very Spicy" required /> Indian Very Spicy</label>
            </div>

            <!-- Biryani Extras -->
            <label for="biryani-extras">Biryani Extras (Optional - Choose as many as you like):</label>
            <div id="biryani-extras-options" style="display: flex; flex-wrap: wrap; gap: 10px; margin: 10px 0;">
                <label><input type="checkbox" name="biryani-extra" value="Extra Raitha 4oz" /> Extra Raitha 4oz + $1.00</label>
                <label><input type="checkbox" name="biryani-extra" value="Extra Raitha 8oz" /> Extra Raitha 8oz + $2.00</label>
                <label><input type="checkbox" name="biryani-extra" value="Extra Salan 4oz" /> Extra Salan 4oz + $1.00</label>
                <label><input type="checkbox" name="biryani-extra" value="Extra Salan 8oz" /> Extra Salan 8oz + $2.00</label>
                <label><input type="checkbox" name="biryani-extra" value="Extra Onion" /> Extra Onion + $1.00</label>
                <label><input type="checkbox" name="biryani-extra" value="Extra Onion & Lemon" /> Extra Onion & Lemon + $2.00</label>
                <label><input type="checkbox" name="biryani-extra" value="Extra Fried Onion" /> Extra Fried Onion 4oz + $2.00</label>
            </div>

            <!-- Quantity and Special Instructions -->
            <label for="quantity">Quantity:</label>
            <input type="number" id="quantity" value="1" min="1" style="width: 50px;" />
            <br><br>
            <textarea id="special-instructions" placeholder="Add special instructions here..." style="width: 100%; height: 60px;"></textarea>
            <br><br>

            <!-- Add to Cart Button -->
            <button style="background-color: #28a745; color: white; border: none; padding: 10px 20px; font-size: 14px; border-radius: 5px; cursor: pointer;" onclick="addToCart()">Add to Cart</button>
        </div>
        <script>
            // A placeholder for the cart items
            let cart = [];

            function openModal(name, image, description, price) {
                document.getElementById('modal').style.display = 'block';
                document.getElementById('modal-image').src = image;
                document.getElementById('modal-name').innerText = name;
                document.getElementById('modal-description').innerText = description;
                document.getElementById('modal-price').innerText = price;
            }

            function closeModal() {
                document.getElementById('modal').style.display = 'none';
            }

            function addToCart() {
                // Get dish details
                const name = document.getElementById('modal-name').innerText;
                const price = document.getElementById('modal-price').innerText;
                const spiceLevel = document.querySelector('input[name="spice-level"]:checked')?.value || "Not Selected";
                const quantity = parseInt(document.getElementById('quantity').value) || 1;
                const instructions = document.getElementById('special-instructions').value;

                // Get selected extras
                const extras = Array.from(document.querySelectorAll('input[name="biryani-extra"]:checked')).map(extra => extra.value);

                // Create a cart item object
                const cartItem = {
                    name,
                    price,
                    spiceLevel,
                    quantity,
                    instructions,
                    extras
                };

                // Add to cart
                cart.push(cartItem);

                // Update the cart display (for demo purposes, we'll log it in the console)
                console.log("Cart:", cart);

                // Optionally, show a confirmation message
                alert(`${name} added to cart!`);

                // Close the modal
                closeModal();
            }
        </script>
        """)

        # Interactivity
        selected_preference.change(filter_menu, inputs=[selected_preference], outputs=[menu_output])

        # Layout
        gr.Row([selected_preference])
        gr.Row(menu_output)
        gr.Row(modal_window)

    return demo

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