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): 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 # 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") # Menu container menu_container = gr.Group(visible=True, elem_id="menu-container") with menu_container: # 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")) # Cart container cart_container = gr.Group(visible=True, elem_id="cart-container") with cart_container: # Floating cart display cart_output = gr.HTML(value="Your cart is empty.", elem_id="floating-cart") # Summary container summary_container = gr.Group(visible=False, elem_id="summary-container") with summary_container: summary_output = gr.HTML(value="", elem_id="summary-container") # Finalize Order Button finalize_button = gr.Button("View Summary") # Finalize order button click event finalize_button.click(lambda: "", inputs=[], outputs=[], _js="showSummary") # Update menu dynamically based on preference selected_preference.change(filter_menu, inputs=[selected_preference], outputs=[menu_output]) # Layout gr.Row([menu_container]) gr.Row([cart_container]) gr.Row([finalize_button]) gr.Row([summary_container]) gr.HTML(modal_and_cart_js) return demo if __name__ == "__main__": demo = app() demo.launch()