Notifications#
Examples of adding notifications per client in Viser.
1import time
2
3import viser
4
5
6def main() -> None:
7 server = viser.ViserServer()
8
9 persistent_notif_button = server.gui.add_button(
10 "Show persistent notification (default)"
11 )
12 timed_notif_button = server.gui.add_button("Show timed notification")
13 controlled_notif_button = server.gui.add_button("Show controlled notification")
14 loading_notif_button = server.gui.add_button("Show loading notification")
15
16 remove_controlled_notif = server.gui.add_button("Remove controlled notification")
17
18 @persistent_notif_button.on_click
19 def _(event: viser.GuiEvent) -> None:
20 """Show persistent notification when the button is clicked."""
21 client = event.client
22 assert client is not None
23
24 client.add_notification(
25 title="Persistent notification",
26 body="This can be closed manually and does not disappear on its own!",
27 loading=False,
28 with_close_button=True,
29 auto_close=False,
30 )
31
32 @timed_notif_button.on_click
33 def _(event: viser.GuiEvent) -> None:
34 """Show timed notification when the button is clicked."""
35 client = event.client
36 assert client is not None
37
38 client.add_notification(
39 title="Timed notification",
40 body="This disappears automatically after 5 seconds!",
41 loading=False,
42 with_close_button=True,
43 auto_close=5000,
44 )
45
46 @controlled_notif_button.on_click
47 def _(event: viser.GuiEvent) -> None:
48 """Show controlled notification when the button is clicked."""
49 client = event.client
50 assert client is not None
51
52 controlled_notif = client.add_notification(
53 title="Controlled notification",
54 body="This cannot be closed by the user and is controlled in code only!",
55 loading=False,
56 with_close_button=False,
57 auto_close=False,
58 )
59
60 @remove_controlled_notif.on_click
61 def _(_) -> None:
62 """Remove controlled notification."""
63 controlled_notif.remove()
64
65 @loading_notif_button.on_click
66 def _(event: viser.GuiEvent) -> None:
67 """Show loading notification when the button is clicked."""
68 client = event.client
69 assert client is not None
70
71 loading_notif = client.add_notification(
72 title="Loading notification",
73 body="This indicates that some action is in progress! It will be updated in 3 seconds.",
74 loading=True,
75 with_close_button=False,
76 auto_close=False,
77 )
78
79 time.sleep(3.0)
80
81 loading_notif.title = "Updated notification"
82 loading_notif.body = "This notification has been updated!"
83 loading_notif.loading = False
84 loading_notif.with_close_button = True
85 loading_notif.auto_close = 5000
86 loading_notif.color = "green"
87
88 while True:
89 time.sleep(1.0)
90
91
92if __name__ == "__main__":
93 main()