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
|
# -----------------------------------------------------------------------------
# trame
# -----------------------------------------------------------------------------
from trame.app import get_server
from trame.widgets import html
CLIENT_TYPE = "vue3"
if CLIENT_TYPE == "vue2":
from trame.ui.vuetify2 import SinglePageLayout
from trame.widgets import vuetify2 as vuetify
else:
from trame.ui.vuetify3 import SinglePageLayout
from trame.widgets import vuetify3 as vuetify
server = get_server()
server.client_type = CLIENT_TYPE
state, ui = server.state, server.ui # ui is an instance of VirtualNodeManager
def my_component(name):
"""Emulate a component that is discovered at runtime"""
vname = f"my_comp_val_{name}"
with state: # Force to update state before template
state.setdefault(vname, 0)
html.Div(name)
vuetify.VBtn("{{" + vname + "}}", click=f"{vname}++")
def udpate_content():
with ui.customizable_slot.clear():
my_component(state.demanded_name)
# -----------------------------------------------------------------------------
# GUI (Layout)
# -----------------------------------------------------------------------------
# virtualnodes added to layout
with SinglePageLayout(server) as layout:
with layout.content as content:
content.clear()
vuetify.VTextField(v_model=("demanded_name", "init"))
vuetify.VBtn("update content", click=udpate_content)
with html.Div():
ui.customizable_slot(layout)
# -----------------------------------------------------------------------------
# Main
# -----------------------------------------------------------------------------
if __name__ == "__main__":
server.start(open_browser=False)
|