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"""

{item['Dish Name']}

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

{item['Description']}

{item['Dish Name']}
""" return html_content # Gradio app definition def app(): with gr.Blocks(title="Dynamic Menu with Preferences") as demo: # 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")) # Define interactivity selected_preference.change(filter_menu, inputs=[selected_preference], outputs=[menu_output]) # Layout gr.Markdown("## Dynamic Menu with Preferences") with gr.Row(): selected_preference.render() menu_output.render() return demo # Run the app if __name__ == "__main__": demo = app() demo.launch()