menu_documentation.py 1.1 KB

123456789101112131415161718192021222324252627282930
  1. from nicegui import ui
  2. from . import doc
  3. @doc.demo(ui.menu)
  4. def main_demo() -> None:
  5. with ui.row().classes('w-full items-center'):
  6. result = ui.label().classes('mr-auto')
  7. with ui.button(icon='menu'):
  8. with ui.menu() as menu:
  9. ui.menu_item('Menu item 1', lambda: result.set_text('Selected item 1'))
  10. ui.menu_item('Menu item 2', lambda: result.set_text('Selected item 2'))
  11. ui.menu_item('Menu item 3 (keep open)',
  12. lambda: result.set_text('Selected item 3'), auto_close=False)
  13. ui.separator()
  14. ui.menu_item('Close', menu.close)
  15. @doc.demo('Client-side auto-close', '''
  16. Use the `auto-close` prop to automatically close the menu on any click event directly without a server round-trip.
  17. ''')
  18. def auto_close():
  19. with ui.button(icon='menu'):
  20. with ui.menu().props('auto-close'):
  21. toggle = ui.toggle(['fastfood', 'cake', 'icecream'], value='fastfood')
  22. ui.icon('', size='md').bind_name_from(toggle, 'value')
  23. doc.reference(ui.menu)