Showcase Dashboard Code Examples
showcase_dashboard_code.Rmdπ View the Live Demo
See this code in action! Click here to view the Showcase Dashboard live demo β
Or run it yourself: dashboardr::showcase_dashboard()
Overview
This vignette provides the exact R code for each
visualization in the Showcase Dashboard. Each section shows the complete
add_viz() call as it appears in the
showcase_dashboard() function source code.
Click on any visualization in the live demo to see the βView R Codeβ accordion, which links back to the corresponding section here.
Data Preparation
library(dashboardr)
library(dplyr)
# Load GSS panel data
data(gss_panel20, package = "gssr")
# Clean and select relevant variables
gss_clean <- gss_panel20 %>%
select(
age_1a, sex_1a, degree_1a, region_1a,
happy_1a, trust_1a, fair_1a, helpful_1a,
polviews_1a, partyid_1a, class_1a
) %>%
filter(if_any(everything(), ~ !is.na(.)))Demographics & Education Tabset
Happiness by Education
add_viz(type = "stackedbar",
x_var = "degree_1a",
stack_var = "happy_1a",
title = "Happiness Distribution Across Education Levels",
subtitle = "Percentage breakdown within each education category",
x_label = "Education Level",
y_label = "Percentage of Respondents",
stack_label = "Happiness Level",
stacked_type = "percent",
x_order = c("Lt High School", "High School", "Junior College", "Bachelor", "Graduate"),
stack_order = c("Very Happy", "Pretty Happy", "Not Too Happy"),
tooltip_suffix = "%",
color_palette = c("#2E86AB", "#A23B72", "#F18F01"),
text = "How happy are you with your life right now?",
text_position = "above",
icon = "ph:chart-bar",
height = 500,
tabgroup = "demographics")Happiness by Gender
add_viz(type = "stackedbar",
x_var = "sex_1a",
stack_var = "happy_1a",
title = "Happiness Distribution by Gender",
subtitle = "Gender differences in reported happiness levels",
x_label = "Gender",
y_label = "Percentage of Respondents",
stack_label = "Happiness Level",
stacked_type = "percent",
stack_order = c("Very Happy", "Pretty Happy", "Not Too Happy"),
tooltip_suffix = "%",
color_palette = c("#2E86AB", "#A23B72", "#F18F01"),
text = "How happy are you with your life right now?",
text_position = "below",
icon = "ph:gender-intersex",
height = 450,
tabgroup = "demographics")Political Attitudes Tabset
Party ID by Political Views
add_viz(type = "stackedbar",
x_var = "polviews_1a",
stack_var = "partyid_1a",
title = "Party ID by Political Views",
subtitle = "Distribution of party identification across political ideology",
x_label = "Political Views",
y_label = "Percentage of Respondents",
stack_label = "Party ID",
stacked_type = "percent",
tooltip_suffix = "%",
color_palette = c("#1f77b4", "#ff7f0e", "#2ca02c", "#d62728", "#9467bd", "#8c564b", "#e377c2"),
text = "This shows how party identification aligns with political ideology.",
text_position = "above",
icon = "ph:users-three",
height = 550,
tabgroup = "politics")Trust by Region
add_viz(type = "stackedbar",
x_var = "region_1a",
stack_var = "trust_1a",
title = "Trust Levels by US Region",
subtitle = "Regional variation in interpersonal trust",
x_label = "US Region",
y_label = "Percentage of Respondents",
stack_label = "Trust Level",
stack_order = c("Can Trust", "Can't Be Too Careful", "Depends"),
stacked_type = "percent",
tooltip_suffix = "%",
color_palette = c("#2E8B57", "#DAA520", "#CD5C5C"),
text = "Do you think you can usually trust strangers?",
text_position = "below",
icon = "ph:map-pin",
height = 500,
tabgroup = "politics")Gender by Social Class
add_viz(type = "stackedbar",
x_var = "class_1a",
stack_var = "sex_1a",
title = "Gender Distribution Across Social Classes",
subtitle = "With custom labels and ordering",
x_label = "Self-Reported Social Class",
y_label = "Number of Respondents",
stack_label = "Gender",
x_order = c("Lower Class", "Working Class", "Middle Class", "Upper Class"),
stack_order = c("Female", "Male"),
stacked_type = "counts",
tooltip_prefix = "Count: ",
color_palette = c("#E07A5F", "#3D5A80"),
text = "Gender distribution across different social class categories.",
text_position = "above",
icon = "ph:chart-pie",
height = 450,
tabgroup = "politics")Note: This chart uses
stacked_type = "counts" instead of βpercentβ.
Social Issues Tabset
Trust by Education and Age
add_viz(type = "heatmap",
x_var = "degree_1a",
y_var = "age_1a",
value_var = "trust_1a",
title = "Trust by Education and Age",
subtitle = "Average trust levels across education and age groups",
x_label = "Education Level",
y_label = "Age Group",
value_label = "Trust Level",
x_order = c("Lt High School", "High School", "Junior College", "Bachelor", "Graduate"),
color_palette = c("#d7191c", "#fdae61", "#ffffbf", "#abdda4", "#2b83ba"),
tooltip_prefix = "Trust: ",
tooltip_suffix = "/3",
tooltip_labels_format = "{point.value:.2f}",
text = "This heatmap reveals trust patterns across education and age groups.",
text_position = "below",
icon = "ph:heatmap",
height = 600,
tabgroup = "social")Trust by Region and Education
add_viz(type = "heatmap",
x_var = "region_1a",
y_var = "degree_1a",
value_var = "trust_1a",
title = "Trust by Region and Education",
subtitle = "Educational and regional patterns in trust levels",
x_label = "Region",
y_label = "Education Level",
value_label = "Trust Level",
y_order = c("Lt High School", "High School", "Junior College", "Bachelor", "Graduate"),
color_palette = c("#d7191c", "#fdae61", "#ffffbf", "#abdda4", "#2b83ba"),
tooltip_prefix = "Trust: ",
tooltip_suffix = "/3",
tooltip_labels_format = "{point.value:.2f}",
text = "Educational and regional patterns in trust distribution.",
text_position = "above",
icon = "ph:chart-pie",
height = 550,
tabgroup = "social")Standalone Summary Charts
Overall Happiness by Education
add_viz(type = "stackedbar",
x_var = "degree_1a",
stack_var = "happy_1a",
title = "Overall Happiness by Education",
subtitle = "Complete distribution of happiness across education levels",
x_label = "Education Level",
y_label = "Percentage of Respondents",
stack_label = "Happiness Level",
stacked_type = "percent",
x_order = c("Lt High School", "High School", "Junior College", "Bachelor", "Graduate"),
stack_order = c("Very Happy", "Pretty Happy", "Not Too Happy"),
tooltip_suffix = "%",
color_palette = c("#2E86AB", "#A23B72", "#F18F01"),
text = "How happy are you?",
text_position = "above",
icon = "ph:chart-bar",
height = 600)Overall Trust by Politics
add_viz(type = "heatmap",
x_var = "partyid_1a",
y_var = "polviews_1a",
value_var = "trust_1a",
title = "Overall Trust by Politics",
subtitle = "Complete trust patterns across political groups",
x_label = "Party Identification",
y_label = "Political Views",
value_label = "Trust Level",
x_order = c("Strong Democrat", "Not Very Strong Democrat", "Independent, Close to Democrat",
"Independent", "Independent, Close to Republican", "Not Very Strong Republican", "Strong Republican"),
y_order = c("Extremely Liberal", "Liberal", "Slightly Liberal", "Moderate",
"Slightly Conservative", "Conservative", "Extremely Conservative"),
color_palette = c("#d7191c", "#fdae61", "#ffffbf", "#abdda4", "#2b83ba"),
tooltip_prefix = "Trust: ",
tooltip_suffix = "/3",
tooltip_labels_format = "{point.value:.2f}",
text_position = "below",
icon = "ph:shield-check",
height = 700)Visualization Index
| Chart | Type | Page | Tabset | Anchor |
|---|---|---|---|---|
| Happiness by Education | Stacked Bar | GSS Data Analysis | Demographics | #demographics-happiness-education |
| Happiness by Gender | Stacked Bar | GSS Data Analysis | Demographics | #demographics-happiness-gender |
| Party ID by Political Views | Stacked Bar | GSS Data Analysis | Politics | #politics-party-views |
| Trust by Region | Stacked Bar | GSS Data Analysis | Politics | #politics-trust-region |
| Gender by Social Class | Stacked Bar | GSS Data Analysis | Politics | #politics-gender-class |
| Trust by Education & Age | Heatmap | GSS Data Analysis | Social Issues | #social-trust-education-age |
| Trust by Region & Education | Heatmap | GSS Data Analysis | Social Issues | #social-trust-region-education |
| Overall Happiness | Stacked Bar | Summary Charts | - | #summary-happiness-education |
| Overall Trust by Politics | Heatmap | Summary Charts | - | #summary-trust-politics |
Next Steps
- View the live Showcase Dashboard β
- See the Tutorial Dashboard Code for simpler examples
- Explore visualization vignettes for detailed chart customization