windows.py 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. from typing import Callable, Literal, Optional, Union
  2. from nicegui import ui
  3. WindowType = Literal['python', 'bash', 'browser']
  4. WINDOW_BG_COLORS = {
  5. 'python': ('#eef5fb', '#2b323b'),
  6. 'bash': ('#e8e8e8', '#2b323b'),
  7. 'browser': ('#ffffff', '#181c21'),
  8. }
  9. def _dots() -> None:
  10. with ui.row().classes('gap-1 relative left-[1px] top-[1px]'):
  11. ui.icon('circle').classes('text-[13px] text-red-400')
  12. ui.icon('circle').classes('text-[13px] text-yellow-400')
  13. ui.icon('circle').classes('text-[13px] text-green-400')
  14. def _window(type_: WindowType, *, title: str = '', tab: Union[str, Callable] = '', classes: str = '') -> ui.column:
  15. bar_color = ('#00000010', '#ffffff10')
  16. color = WINDOW_BG_COLORS[type_]
  17. with ui.card().classes(f'no-wrap bg-[{color[0]}] dark:bg-[{color[1]}] rounded-xl p-0 gap-0 {classes}') \
  18. .style('box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1)'):
  19. with ui.row().classes(f'w-full h-8 p-2 bg-[{bar_color[0]}] dark:bg-[{bar_color[1]}]'):
  20. _dots()
  21. if title:
  22. ui.label(title) \
  23. .classes('text-sm text-gray-600 dark:text-gray-400 absolute left-1/2 top-[6px]') \
  24. .style('transform: translateX(-50%)')
  25. if tab:
  26. with ui.row().classes('gap-0'):
  27. with ui.label().classes(f'w-2 h-[24px] bg-[{color[0]}] dark:bg-[{color[1]}]'):
  28. ui.label().classes(
  29. f'w-full h-full bg-[{bar_color[0]}] dark:bg-[{bar_color[1]}] rounded-br-[6px]')
  30. with ui.row().classes(f'text-sm text-gray-600 dark:text-gray-400 px-6 py-1 h-[24px] rounded-t-[6px] bg-[{color[0]}] dark:bg-[{color[1]}] items-center gap-2'):
  31. if callable(tab):
  32. tab()
  33. else:
  34. ui.label(tab)
  35. with ui.label().classes(f'w-2 h-[24px] bg-[{color[0]}] dark:bg-[{color[1]}]'):
  36. ui.label().classes(
  37. f'w-full h-full bg-[{bar_color[0]}] dark:bg-[{bar_color[1]}] rounded-bl-[6px]')
  38. return ui.column().classes('w-full h-full overflow-auto')
  39. def python_window(title: Optional[str] = None, *, classes: str = '') -> ui.column:
  40. """Create a window for Python code."""
  41. return _window('python', title=title or 'main.py', classes=classes).classes('px-4 py-2 python-window')
  42. def bash_window(*, classes: str = '') -> ui.column:
  43. """Create a window for Bash code."""
  44. return _window('bash', title='bash', classes=classes).classes('px-4 py-2 bash-window')
  45. def browser_window(title: Optional[Union[str, Callable]] = None, *, classes: str = '') -> ui.column:
  46. """Create a browser window."""
  47. return _window('browser', tab=title or 'NiceGUI', classes=classes).classes('p-4 browser-window')