main.py 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. #!/usr/bin/env python3
  2. from nicegui import ui
  3. columns = [
  4. {'field': 'name', 'editable': True, 'sortable': True},
  5. {'field': 'age', 'editable': True},
  6. {'field': 'id'},
  7. ]
  8. rows = [
  9. {'id': 0, 'name': 'Alice', 'age': 18},
  10. {'id': 1, 'name': 'Bob', 'age': 21},
  11. {'id': 2, 'name': 'Carol', 'age': 20},
  12. ]
  13. def add_row():
  14. new_id = max(dx['id'] for dx in rows) + 1
  15. rows.append({'id': new_id, 'name': 'New name', 'age': None})
  16. ui.notify(f'Added row with ID {new_id}')
  17. aggrid.update()
  18. def handle_cell_value_change(e):
  19. new_row = e.args['data']
  20. ui.notify(f'Updated row to: {e.args["data"]}')
  21. rows[:] = [row | new_row if row['id'] == new_row['id'] else row for row in rows]
  22. async def delete_selected():
  23. selected_id = [row['id'] for row in await aggrid.get_selected_rows()]
  24. rows[:] = [row for row in rows if row['id'] not in selected_id]
  25. ui.notify(f'Deleted row with ID {selected_id}')
  26. aggrid.update()
  27. aggrid = ui.aggrid({
  28. 'columnDefs': columns,
  29. 'rowData': rows,
  30. 'rowSelection': 'multiple',
  31. 'stopEditingWhenCellsLoseFocus': True,
  32. }).on('cellValueChanged', handle_cell_value_change)
  33. ui.button('Delete selected', on_click=delete_selected)
  34. ui.button('New row', on_click=add_row)
  35. ui.run()