File: 17_hot_reload.py

package info (click to toggle)
python-trame 3.12.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 101,620 kB
  • sloc: python: 13,515; sh: 183; javascript: 93; makefile: 7
file content (91 lines) | stat: -rw-r--r-- 2,821 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
from trame_server.utils.hot_reload import hot_reload

from trame.app import get_server
from trame.ui.vuetify import SinglePageLayout
from trame.widgets import html, vuetify

# -----------------------------------------------------------------------------
# Trame setup
# -----------------------------------------------------------------------------

server = get_server(client_type="vue2")
state, ctrl = server.state, server.controller

# Can do `export TRAME_HOT_RELOAD=1` instead
server.hot_reload = True

# Way to enable widgets when UI creation is deferred after server.start()
html.initialize(server)
vuetify.initialize(server)


# -----------------------------------------------------------------------------
# Dynamically modify any `ChangeMe` to see the new code execute while
# interacting with the app.
# -----------------------------------------------------------------------------
@ctrl.set("number_reset")
def reset_number():
    print("reset_number::ChangeMe")
    state.number = 6
    state.size = 1
    do_someting()


@state.change("number")
def update_number(number, **kwargs):
    print("update_number::ChangeMe", number)
    do_someting()


@hot_reload
def do_someting():
    print("do_someting::ChangeMe")


@ctrl.add("on_server_bind")  # on_server_bind => fn(aiohttp_server)
@ctrl.add("on_server_reload")  # on_server_reload => fn()
def setup_ui(*_):
    with SinglePageLayout(server) as layout:
        layout.title.set_text("Hot Reload - ChangeMe")

        # Toolbar
        with layout.toolbar as toolbar:
            toolbar.dense = True
            vuetify.VSpacer()
            vuetify.VSlider(
                hide_details=True,
                v_model=("number", 6),
                max=60,
                min=3,
                step=1,
                style="max-width: 300px;",
            )
            vuetify.VSlider(
                label="size",
                hide_details=True,
                v_model=("size", 2),
                max=10,
                min=1,
                step=1,
                style="max-width: 300px;",
            )
            with vuetify.VBtn(icon=True, click=ctrl.number_reset):
                vuetify.VIcon("mdi-undo")

        with layout.content:
            with vuetify.VContainer(fluid=True, classes="pa-0 fill-height"):
                with vuetify.VCol():
                    html.Div(
                        "{{ number }} x {{ i }} = {{ number * i }}",
                        v_for="i in size",
                        key="i",
                        classes="mx-auto text-h6 text-center",
                    )


# -----------------------------------------------------------------------------
# start server
# -----------------------------------------------------------------------------

if __name__ == "__main__":
    server.start()