1
0

header.py 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. from pathlib import Path
  2. from typing import Optional
  3. from nicegui import app, ui
  4. from . import svg
  5. from .search import Search
  6. from .star import add_star
  7. HEADER_HTML = (Path(__file__).parent / 'static' / 'header.html').read_text(encoding='utf-8')
  8. STYLE_CSS = (Path(__file__).parent / 'static' / 'style.css').read_text(encoding='utf-8')
  9. def add_head_html() -> None:
  10. """Add the code from header.html and reference style.css."""
  11. ui.add_head_html(HEADER_HTML + f'<style>{STYLE_CSS}</style>')
  12. def add_header(menu: Optional[ui.left_drawer] = None) -> None:
  13. """Create the page header."""
  14. menu_items = {
  15. 'Installation': '/#installation',
  16. 'Features': '/#features',
  17. 'Demos': '/#demos',
  18. 'Documentation': '/documentation',
  19. 'Examples': '/#examples',
  20. 'Why?': '/#why',
  21. }
  22. dark_mode = ui.dark_mode(value=app.storage.browser.get('dark_mode'), on_change=lambda e: ui.run_javascript(f'''
  23. fetch('/dark_mode', {{
  24. method: 'POST',
  25. headers: {{'Content-Type': 'application/json'}},
  26. body: JSON.stringify({{value: {e.value}}}),
  27. }});
  28. '''))
  29. with ui.header() \
  30. .classes('items-center duration-200 p-0 px-4 no-wrap') \
  31. .style('box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1)'):
  32. if menu:
  33. ui.button(on_click=menu.toggle, icon='menu').props('flat color=white round').classes('lg:hidden')
  34. with ui.link(target='/').classes('row gap-4 items-center no-wrap mr-auto'):
  35. svg.face().classes('w-8 stroke-white stroke-2 max-[610px]:hidden')
  36. svg.word().classes('w-24')
  37. with ui.row().classes('max-[1050px]:hidden'):
  38. for title_, target in menu_items.items():
  39. ui.link(title_, target).classes(replace='text-lg text-white')
  40. search = Search()
  41. search.create_button()
  42. with ui.element().classes('max-[420px]:hidden').tooltip('Cycle theme mode through dark, light, and system/auto.'):
  43. ui.button(icon='dark_mode', on_click=lambda: dark_mode.set_value(None)) \
  44. .props('flat fab-mini color=white').bind_visibility_from(dark_mode, 'value', value=True)
  45. ui.button(icon='light_mode', on_click=lambda: dark_mode.set_value(True)) \
  46. .props('flat fab-mini color=white').bind_visibility_from(dark_mode, 'value', value=False)
  47. ui.button(icon='brightness_auto', on_click=lambda: dark_mode.set_value(False)) \
  48. .props('flat fab-mini color=white').bind_visibility_from(dark_mode, 'value', lambda mode: mode is None)
  49. with ui.link(target='https://discord.gg/TEpFeAaF4f').classes('max-[515px]:hidden').tooltip('Discord'):
  50. svg.discord().classes('fill-white scale-125 m-1')
  51. with ui.link(target='https://www.reddit.com/r/nicegui/').classes('max-[465px]:hidden').tooltip('Reddit'):
  52. svg.reddit().classes('fill-white scale-125 m-1')
  53. with ui.link(target='https://github.com/zauberzeug/nicegui/').classes('max-[365px]:hidden').tooltip('GitHub'):
  54. svg.github().classes('fill-white scale-125 m-1')
  55. add_star().classes('max-[550px]:hidden')
  56. with ui.row().classes('min-[1051px]:hidden'):
  57. with ui.button(icon='more_vert').props('flat color=white round'):
  58. with ui.menu().classes('bg-primary text-white text-lg'):
  59. for title_, target in menu_items.items():
  60. ui.menu_item(title_, on_click=lambda target=target: ui.navigate.to(target))