1
0

main.py 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #!/usr/bin/env python3
  2. from pathlib import Path
  3. from nicegui import ui
  4. @ui.page('/')
  5. def page():
  6. async def connect() -> None:
  7. if not await ui.run_javascript('"serial" in navigator'):
  8. ui.notify('WebSerial is not available in this browser.')
  9. return
  10. if not await ui.run_javascript('connect()', timeout=100):
  11. ui.notify('Could not connect to the device.')
  12. return
  13. ui.run_javascript('readLoop()')
  14. state['connected'] = True
  15. async def disconnect() -> None:
  16. ui.run_javascript('disconnect()', timeout=5)
  17. state['connected'] = False
  18. state = {
  19. 'connected': False,
  20. 'button': False,
  21. }
  22. ui.add_body_html(f'<script>{(Path(__file__).parent / "script.js").read_text(encoding="utf-8")}</script>')
  23. ui.button('Connect', on_click=connect).bind_visibility_from(state, 'connected', value=False)
  24. ui.button('Disconnect', on_click=disconnect).bind_visibility_from(state, 'connected')
  25. ui.switch('LED', on_change=lambda e: ui.run_javascript(f'send({e.value:d})')).bind_enabled_from(state, 'connected')
  26. ui.switch('Button').props('disable').bind_value_from(state, 'button')
  27. ui.on('read', lambda e: state.update(button=e.args == 'LOW'))
  28. ui.run()