Module 28 Review exercise: Shiny & Git
Create a repository on github named
trumpapp
Clone the trumpapp repository into a place on your computer where you’ll easily be able to find it.
Open a blank R script. Save it in the recently cloned
trumpapp
folder asapp.R
.Copy-paste the below code into
app.R
library(shiny)
library(dplyr)
library(readr)
library(shinydashboard)
library(wordcloud2)
library(DT)
ui <- dashboardPage(
dashboardHeader(title = "My app title"),
dashboardSidebar(
sidebarMenu(
menuItem("Dashboard", tabName = "dashboard"),
menuItem("Raw data", tabName = "rawdata")
)
),
dashboardBody(
tabItems(
tabItem("dashboard",
fluidPage(
fluidRow(
h3('Hi, you should replace me'))
)
),
tabItem("rawdata",
fluidPage(
fluidRow(
fluidRow(
h3('Hi, you should replace me'))
)
)
)
)
)
)
# Define server logic required to draw a histogram
server <- function(input, output) {
# Read in data #####################
if('trump.csv' %in% dir()){
trump <- read_csv('trump.csv')
} else {
trump <- read_csv('https://raw.githubusercontent.com/databrew/intro-to-data-science/main/data/trumptweets.csv')
write_csv(trump, 'trump.csv')
}
# end of data read-in ##############
}
# Run the application
shinyApp(ui = ui, server = server)
Run the app to make sure it works.
Replace the “My app title” with a title of your choosing.
Replace the
h3('Hi, you should replace me')
line with two “columns”, the latter twice the width of the former. For example:
In the column of width 4, add a “text input”. This is a place the user of the app can write anything they want.
In the server part of the app, after the data read-in section, create a “reactive” dataframe. A reactive dataframe is a dataframe that automatically adjusts based on user input. To do this, use the below code:
dfr <- reactive({
user_text <- tolower(input$user_text) # change this to whatever ID you gave to the object you created in number 8
out <- trump %>% filter(grepl(user_text, tolower(content)))
out
})
Create a plot output in the server. This should be named something like
output$my_plot
and should use therenderPlot({})
function. Make this plot be the number of times that the word/string searched for by the user appeared in Trump’s tweets, for each year month.Refer to
my_plot
correctly in the UI so that the plot shows up. Test that the plot works.Add a slider input to your app so that the user can filter down the date range of the period covered. Make sure the dates from the slider input are appropriately passed to your app.
Look up the
datatable
function. It is part of theDT
library.In the
rawdata
tab of your app, show the “raw” data of the tweets which match the text input from the user. You’ll needrenderDataTable
anddataTableOutput
.Add another slider which allows users to filter by time of day.
Push your code to github.
Publish your app to shinyapps.io. Send a link to your code and app to sewanee@databrew.cc.
You just made a cool Trump tweet data explorer, and you’re all done, and you’re waiting on everyone else to finish? Congratulations! Now make a Shakespeare data explorer. Good luck. ;)