File: dynamic_layout.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 (44 lines) | stat: -rw-r--r-- 1,259 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
from trame.app import get_server
from trame.ui.html import DivLayout
from trame.widgets import html

# -----------------------------------------------------------------------------
# Trame app
# -----------------------------------------------------------------------------

server = get_server()

# -----------------------------------------------------------------------------
# UI setup
# -----------------------------------------------------------------------------

line_count = 1


def update_first_line():
    global line_count
    with server.ui.first_line:
        server.ui.first_line.clear()
        html.Div(f"First line: {line_count}")
    line_count += 1


# Start with some UI to control a
with DivLayout(server) as layout:
    server.ui.first_line(layout)  # Insert place holder

    def add_line():
        global line_count
        with layout:
            html.Div(f"Line: {line_count}")
        line_count += 1

    html.Button("Add line", click=add_line)
    html.Button("Update first line", click=update_first_line)

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

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