Elysium of Elements 🌈¶
"Congratulations my weary friends. You've reached the Elysium of Elements
This land is home to all the knowledge you seek, complete with archives and resources on Plotly, Dash Core, and Dash Bootstrap. As the last chapter before your quest's finale, I'd recommend exploring a few of these elements... you never know what you may find"
And with that, our mysterious friend floats away, leaving us in a sea of clouds, surrounded by small exhibit booths neatly organized in seemingly infinite lines.
The one closest to us reads "Presenting Plotly Paradise"...
Elysium of Elements 01
Plotly Paradise¶
Although we've explored several core Plotly figures that are used extensively across dashboards, there are a myriad of other charts that can be made using Plotly. In this section, we'll explore a few of them.
NOTE: Feel free to submit requests for other elements. This chapter may be updated to include them as well!
Radar Charts¶
Radar charts are used to visualize different traces across different axes. For example, if one wished to compare restaurants across five different categories, a radar chart would be a perfect visualization.
Let's take a look at creating one with Plotly.
categories = ['Food', 'Service', 'Affordable', 'Location', 'Ambience']
res = {
"Pop's Pizzas" : [3, 3, 5, 4, 3],
"Tony's Tacos" : [5, 2, 4, 1, 2],
"Bill's Bread" : [2, 4, 1, 2, 4],
}
fig = go.Figure()
for restaurant in res:
fig.add_trace(go.Scatterpolar(
r=res[restaurant],
theta=categories,
fill='toself',
name=restaurant,
))
fig.update_layout(
polar=dict(
radialaxis=dict(
visible=True
),
),
width=800
)
fig.show()
As seen, we create a go.Figure()
and add multiple traces. Each trace represents
a distinct data entity, in this case different restaurants. Each restaurant has been
scored across different categories, and categories are stored in theta
, while each
value is stored in r
. In fig.update_layout()
, the figure is converted into polar form to create our circular
radar chart. It's a lot easier to visualize how each restaurant compares!
NOTE: This format is similar to polar axes, where each point is determine in r and theta instead of x and y.
data:image/s3,"s3://crabby-images/a7401/a74010effb37c9974ab74cc8834806d31cf7fb0b" alt="Radar1"
NOTE: For more resources on Radar Charts, feel free to check out the following resources: Plotly Radar
3-D Figures¶
In order to create 3D plots, we can use the px.scatter_3d()
function. This simply
requires us to enter a list value for x, y, and z. Dataframes can also be used to
create a 3-D figure, formatted the same as with px.scatter()
.
Here's an example of a 3D parabolic curve:
import numpy as np
t = np.linspace(-10, 10, 50)
x = t
y = t**2
z = 3*x - 2*y
fig = px.scatter_3d(x=x, y=y, z=z)
fig.show()
NOTE:
np.linspace()
simply creates a list from -10 to 10, with 50 data points in between, spaced evenly.
data:image/s3,"s3://crabby-images/e4923/e49237f1e659cc40e94cd0d3fcd26909378cacd8" alt="ThreeD1"
NOTE: For more information on Radar Charts, feel free to check out the following resources: Scatter, 3D Charts
Choropleth (Maps)¶
Plotly allows for the creation and insertion of geographical maps using geojson
data. Choropleth maps
allow for the visulization of distinct geographical zones with different colors to indicate different attributes.
In order to use the Plotly Choropleth example, we need to install the following.
!pip install -U plotly
from urllib.request import urlopen
import json
import pandas as pd
import plotly.express as px
NOTE: We need to upgrade our version of Plotly to the latest to ensure that Choropleth works!
Now, we can use the Plotly datasets in order to visualize the unemployment in the United States.
with urlopen('https://raw.githubusercontent.com/plotly/datasets/master/geojson-counties-fips.json') as response:
counties = json.load(response)
df = pd.read_csv("https://raw.githubusercontent.com/plotly/datasets/master/fips-unemp-16.csv",
dtype={"fips": str})
fig = px.choropleth(df, geojson=counties, locations='fips', color='unemp',
color_continuous_scale="Viridis",
range_color=(0, 12),
scope="usa",
labels={'unemp':'unemployment rate'}
)
fig.update_layout(margin={"r":0,"t":0,"l":0,"b":0})
fig.show()
data:image/s3,"s3://crabby-images/2911c/2911c6c6aeced9457274840121b42b678dd86d73" alt="Map1"
As seen, it's quite a detailed, interactive map!
NOTE: For more information on Maps, feel free to check out the following resources: Choropleth
We turn to the next booth and continue reading...
Elysium of Elements 02
Bootstrap Bliss¶
As with Plotly, there are dozens of other unique Bootstrap components that can be incorporated into one's dashboard. Although we've covered the core elements, we'll explore three more in this section.
NOTE: For a comprehensive list on all bootstrap components, feel free to check out: Dash Bootstrap
Progress Bars¶
Progress bars are horizontal, rounded rectangles that are quite flexible when it comes to displaying progress.
Here's an example of a progress bar with three distinct sections.
progress = dbc.Progress(
[
dbc.Progress(value=20, color="success", bar=True),
dbc.Progress(value=30, color="warning", bar=True),
dbc.Progress(value=20, color="danger", bar=True),
],
multi=True,
)
app = JupyterDash(__name__, external_stylesheets=[dbc.themes.BOOTSTRAP])
app.layout = html.Div(children=[
dbc.Col(progress, width=6)
])
app.run_server(mode='external')
data:image/s3,"s3://crabby-images/34406/3440663c7f34943f1d216d48af2ec258988fa635" alt="Progress1"
As seen, each bar section has a different color and length (value
).
This bar can also be animated, controlled via a button that toggles the bar on and off.
progress = html.Div(
[
dbc.Progress(
value=80, id="animated-progress", animated=False, striped=True
),
dbc.Button(
"Toggle animation",
id="animation-toggle",
className="mt-3",
n_clicks=0,
),
]
)
app = JupyterDash(__name__, external_stylesheets=[dbc.themes.BOOTSTRAP])
app.layout = html.Div(children=[
dbc.Col(progress, width=6)
])
@app.callback(
dash.dependencies.Output("animated-progress", "animated"),
[dash.dependencies.Input("animation-toggle", "n_clicks")],
[dash.dependencies.State("animated-progress", "animated")],
)
def toggle_animation(n, animated):
if n:
return not animated
return animated
app.run_server(mode='external')
data:image/s3,"s3://crabby-images/19a72/19a7231233a6375fc18795f8424f76f1cf0227d1" alt="Progress1"
Ah-ah, one interesting addition is the variable dash.dependencies.State
as
part of our app's callback. This simply means that the state of the progress bar
(whether it is currently animated or not) is also used to determine the output. This
makes sense, since our toggle button inverts whatever the state of the progress bar is.
NOTE: For more information on progress bars, feel free to check out the following resources: Progress
Spinners¶
Next up, spinners! These components are small circles that move to indicate that a process is occurring.
Here are three examples (one small, one big, and one growing).
spinners = html.Div(
[
dbc.Row([
dbc.Col(dbc.Spinner(size="sm", color="info"), width=1),
dbc.Col(dbc.Spinner(spinner_style={"width": "3rem", "height": "3rem"}, color="success"), width=1),
dbc.Col(dbc.Spinner(color="danger", type="grow"), width=1),
])
]
)
app = JupyterDash(__name__, external_stylesheets=[dbc.themes.BOOTSTRAP])
app.layout = html.Div(children=[
dbc.Col(spinners, width=6)
])
app.run_server(mode='external')
data:image/s3,"s3://crabby-images/281ad/281ad112a1571c5b9da1728c97f57ec76666d971" alt="Spinner1"
Each can be easily colored, resized, and toggled between traditional mode and growing mode. Spinners can also be used to indicate loading, or to be displayed upon a user action. For example, the following displays a spinner based on the number of times the button is pressed. After the time has elapsed, the spinner is replaced with the output.
import time
loading_spinner = html.Div(
[
dbc.Button("Counter", id="loading-button", n_clicks=0),
dbc.Spinner(html.Div(id="loading-output")),
]
)
app = JupyterDash(__name__, external_stylesheets=[dbc.themes.BOOTSTRAP])
app.layout = html.Div(children=[
dbc.Col(loading_spinner, width=3)
])
@app.callback(
dash.dependencies.Output("loading-output", "children"),
[dash.dependencies.Input("loading-button", "n_clicks")]
)
def load_output(n):
if n:
time.sleep(1)
return f"You have clicked {n} times"
return "No clicks as of yet ;("
app.run_server(mode='external')
data:image/s3,"s3://crabby-images/3ecda/3ecda62ec6d34efe9aea9a43860455646b689e21" alt="Spinner2"
NOTE: For more information on spinners, feel free to check out the following resources: Dash Spinners
Alerts¶
Next up, Dash Alerts! These components are used to display important information, such as messages, information the user should know before proceeding, or any other form of alerts. Like all bootstrap, they are quite flexible.
Here's an example with two alerts, one of them dismissible (able to be closed) and the other permanent.
alerts = html.Div([
dbc.Alert("This is a success alert! Luckily, I won't leave!", color="success"),
dbc.Alert("This is a warning alert, but you can close me!", color="warning", dismissable=True),
])
app = JupyterDash(__name__, external_stylesheets=[dbc.themes.BOOTSTRAP])
app.layout = html.Div(children=[
dbc.Col(alerts, width=6)
])
app.run_server(mode='external')
data:image/s3,"s3://crabby-images/eb001/eb001528c1337219a76654815d27728537787b45" alt="Alert1"
These alarms can be easily customized in terms of color and content. Additionally, they can be set to automatically
disappear after a certain amount of time. This is done via the keyword duration
, which takes in milliseconds.
Here's an example with a disappearing alert, accompanied by a button that toggles the state of the alert.
alert = html.Div(
[
dbc.Button(
"Switch States", id="alert-toggle-auto", className="mr-1", n_clicks=0
),
html.Hr(),
dbc.Alert(
"I will disappear in 3 seconds...",
id="alert-auto",
color="danger",
is_open=True,
duration=3000, # In milliseconds
),
]
)
app = JupyterDash(__name__, external_stylesheets=[dbc.themes.BOOTSTRAP])
app.layout = html.Div(children=[
dbc.Col(alert, width=6)
])
@app.callback(
dash.dependencies.Output("alert-auto", "is_open"),
[dash.dependencies.Input("alert-toggle-auto", "n_clicks")],
[dash.dependencies.State("alert-auto", "is_open")],
)
def toggle_alert(n, is_open):
if n:
return not is_open
return is_open
app.run_server(mode='external')
data:image/s3,"s3://crabby-images/b86dc/b86dcbd1e99bbc89daacccb5b7bc55e3f560e193" alt="Alert2"
Quite handy, especially to help users navigate a dashboard for the first time!
NOTE: For more information on alerts, feel free to check out the following resources: Dash Alerts
A booming voice announces,
"Dear dashboarders, our time in the Elysium is almost up. However, before continuing, let's take a closer look to see all the powerful Plotly + Dash that you've learned along the way"
Elysium of Elements 03
Dash Dreamland¶
There are hundreds of more Dash elements, including Dash Core Components, Dash Bootstrap Components, Plotly, Ploly Express, HTML, and more. Diving into these elements is beyond the scope of this introductory journey!
However, here's a quick summary of everything we've learned along the way, a sort of cheat-sheet...
Plotly Charts | Dash/Tigergraph | HTML | Dash Core | Bootstrap |
---|---|---|---|---|
Bar Charts | Layout Functions | Div | Graphs | Cards |
Line Charts | Styling App | Headers | Markdown | Row/Col |
Pie Charts | Multi-Paged | Paragraph | Location | Badges |
Scatter Plots | Callbacks | Bold/Italic | Links | ListGroup |
Cytoscape | Navbars | Center | Input | Jumbotron |
Radar Charts | Sidebars | Link | Dropdown | Button |
3-D Figures | Create Solution | Hr. Rule | Table | |
Choropleth | Connect w/ pyTG | Line Break | Progress | |
Install Queries | Image | Spinner | ||
Run Queries | Alert |
Feel free to utilize the "Search" box at the top right of this webpage to quickly reference each.
We've learned quite a lot within the span of less than a dozen chapters 😄.
"Now, it is time to complete your quest."
The mysterious figure who greeted us returns, and with a wave of their hands, we find ourselves sitting across from them at a round table. A sign behind them reads, "Destination Deployment"
-
All code segments from this chapter can be found in this Colab Notebook. Feel free to follow along! ↩
-
Everything we've installed so far (prerequistes for next section):
↩!pip install -q pyTigerGraph import pyTigerGraph as tg TG_SUBDOMAIN = 'healthcare-dash' TG_HOST = "https://" + TG_SUBDOMAIN + ".i.tgcloud.io" # GraphStudio Link TG_USERNAME = "tigergraph" # This should remain the same... TG_PASSWORD = "tigergraph" # Shh, it's our password! TG_GRAPHNAME = "MyGraph" # The name of the graph conn = tg.TigerGraphConnection(host=TG_HOST, graphname=TG_GRAPHNAME, username=TG_USERNAME, password=TG_PASSWORD, beta=True) conn.apiToken = conn.getToken(conn.createSecret()) !pip install -q jupyter-dash import dash import dash_html_components as html from jupyter_dash import JupyterDash import plotly.express as px import pandas as pd import plotly.graph_objects as go import dash_core_components as dcc !pip install dash-bootstrap-components import dash_bootstrap_components as dbc !pip install dash-cytoscape import dash_cytoscape as cyto import numpy as np !pip install -U plotly from urllib.request import urlopen import json import pandas as pd import plotly.express as px import time