-
-
Notifications
You must be signed in to change notification settings - Fork 160
/
Copy pathdashboard.py
70 lines (61 loc) · 1.71 KB
/
dashboard.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
"""Instantiate a Dash app."""
import numpy as np
import pandas as pd
import dash
import dash_table
import dash_html_components as html
import dash_core_components as dcc
from .data import create_dataframe
from .layout import html_layout
def init_dashboard(server):
"""Create a Plotly Dash dashboard."""
dash_app = dash.Dash(
server=server,
routes_pathname_prefix='/dashapp/',
external_stylesheets=[
'/static/dist/css/styles.css',
'https://fonts.googleapis.com/css?family=Lato'
]
)
# Load DataFrame
df = create_dataframe()
# Custom HTML layout
dash_app.index_string = html_layout
# Create Layout
dash_app.layout = html.Div(
children=[
create_graph(df),
create_data_table(df)
],
id='dash-container'
)
return dash_app.server
def create_data_table(df):
"""Create Dash datatable from Pandas DataFrame."""
table = dash_table.DataTable(
id='database-table',
columns=[{"name": i, "id": i} for i in df.columns],
data=df.to_dict('records'),
sort_action="native",
sort_mode='native',
page_size=300
)
return table
def create_graph(df):
agraph = dcc.Graph(
id='histogram-graph',
figure={
'data': [{
'x': df['complaint_type'],
'text': df['complaint_type'],
'customdata': df['key'],
'name': '311 Calls by region.',
'type': 'histogram'
}],
'layout': {
'title': 'NYC 311 Calls category.',
'height': 500,
'padding': 150
}
})
return agraph