import gradio as gr import pandas as pd import json # 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): menu_data = load_menu() 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: filtered_data = menu_data html_content = "" for _, item in filtered_data.iterrows(): html_content += f"""

{item['Dish Name']}

${item['Price ($)']}

{item['Description']}

\"{item['Dish
""" return html_content # Function to finalize the order and display the final page def finalize_order(cart_json): cart = json.loads(cart_json) if not cart: return "

Your cart is empty. Please add items before finalizing.

" total_bill = 0 final_order_html = "

Your Final Order:

Total Bill: ${total_bill:.2f}

" final_order_html += "

Your final order has been placed. Thank you!

" return final_order_html # JavaScript for modal and cart behavior modal_and_cart_js = """ """ # 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")) # Floating cart display cart_output = gr.HTML(value="Your cart is empty.", elem_id="floating-cart") # Hidden input to store cart data cart_data = gr.Textbox(visible=False, elem_id="cart-data") # Final order display final_order_output = gr.HTML(value="", elem_id="final-page") # Modal window for item customization modal_window = gr.HTML(""" """) # Finalize Order Button finalize_button = gr.Button("Finalize Order") # Finalize order button click event finalize_button.click(finalize_order, inputs=[cart_data], outputs=[final_order_output]) # Update menu dynamically based on preference selected_preference.change(filter_menu, inputs=[selected_preference], outputs=[menu_output]) # Layout gr.Row([selected_preference]) gr.Row(menu_output) gr.Row(cart_output) gr.Row(modal_window) gr.Row(finalize_button) gr.Row(final_order_output) gr.HTML(modal_and_cart_js) return demo if __name__ == "__main__": demo = app() demo.launch()