-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathusage.py
116 lines (103 loc) · 3.46 KB
/
usage.py
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
import dash_draggable
import dash
from dash.dependencies import Input, Output
import dash_html_components as html
import dash_core_components as dcc
import plotly.graph_objs as go
import dash_daq as daq
app = dash.Dash(__name__)
app.scripts.config.serve_locally = True
app.css.config.serve_locally = True
app.config['suppress_callback_exceptions'] = True
app.layout = html.Div([
daq.BooleanSwitch(id='toggle-drag', on=True),
html.Div(id='status'),
html.Div(id='print'),
html.Div(
style={'width': '30vw', 'display': 'inline-flex'},
children=dash_draggable.dash_draggable(
id='draggable',
axis="both",
handle=".handle",
defaultPosition={'x': 0, 'y': 100},
position=None,
grid=[12, 12],
children=[
html.Div(
id='a-div',
className='handle',
children=dcc.Graph(
id='example-graph',
figure={
'data': [
{'x': [1, 2, 3], 'y': [4, 1, 2], 'type': 'bar',
'name': 'SF'},
{'x': [1, 2, 3], 'y': [2, 4, 5], 'type': 'bar',
'name': u'Montréal'},
],
'layout': {
'title': 'Drag anywhere'
}
}
)
)
]
)),
html.Div(
style={'width': '30vw', 'display': 'inline-flex'},
children=dash_draggable.dash_draggable(
id='draggable-2',
axis='x',
handle='.handle',
defaultPosition={'x': 200, 'y': 100},
position=None,
grid=[25, 25],
children=[
html.Div(
id='another-div',
className='handle',
children=[
dcc.Graph(
id='example2',
figure=dict(
data=[go.Pie(
labels=['Oxygen', 'Hydrogen',
'Carbon_Dioxide',
'Nitrogen'],
values=[4500, 2500, 1053, 500],
)],
layout=dict(
title='Drag horizontally'
)
)
)
]
)
]
))
])
@app.callback(
Output('print', 'children'),
[Input('draggable', 'deltaX'),
Input('draggable', 'deltaY')]
)
def print_test(event, position):
return html.Div([html.P("{}".format(position)),
html.P("{}".format(event))])
# Disable/Enable dragging on component
@app.callback(
Output('draggable', 'disabled'),
[Input('toggle-drag', 'on')]
)
def toggle_drag(toggle_status):
# True/False
return not toggle_status
# Tell user if dragging is enabled and for which component
@app.callback(
Output('status', 'children'),
[Input('toggle-drag', 'on')]
)
def can_drag(toggle_status):
return html.P("'Drag Anywhere' Component Draggable: {}".format(toggle_status))
if __name__ == '__main__':
app.run_server(debug=True)