dat <- na.omit(read.csv(file="https://github.com/chinwex/STA553/raw/main/w09/PresidentialElection2000To2020.csv"))
dat$county_fips <- sprintf("%05d", dat$county_fips)
votes = dat$candidatevotes
totalcountyvotes = dat$totalvotes
statedata <- dplyr::summarise(group_by(dat, year, state, state_po), sum.state = sum(candidatevotes))
totalstatevotes = statedata$sum.state

dat1 = dat
dat1$county_percent = (votes/totalcountyvotes)*100
dat1 = dat1[,-c(6,11,12)]

dat2 = dat %>%
  group_by(year, state, state_po, candidate, party) %>%
  dplyr::summarise(state_sum = sum(candidatevotes))

dat2 = dplyr::mutate(group_by(dat2, year, state, state_po), statetotal = sum(state_sum))
dat2$state_percent = ((dat2$state_sum)/dat2$statetotal)*100
dat1final <- dat1 %>%
  group_by(year,state, county_name)%>%
  filter(county_percent == max(county_percent))

dat2final <- dat2 %>%
  group_by(year,state)%>%
  filter(state_percent == max(state_percent))
write.csv(dat1final, file="C:\\Users\\echef\\Documents\\STA553\\week 9\\countysubset.csv")
write.csv(dat2final, file="C:\\Users\\echef\\Documents\\STA553\\week 9\\statesubset.csv")


---
title: "Interactive Visualization with Tableau"
author: "Echefu Chinwendu"
date: "2024-04-02"
output:
  html_document: 
    toc: yes
    toc_depth: 4
    toc_float: yes
    fig_width: 4
    fig_caption: yes
    number_sections: yes
    toc_collapsed: yes
    code_folding: hide
    code_download: yes
    smooth_scroll: true
    theme: readable
    fig_height: 4
  pdf_document: 
    toc: yes
    toc_depth: 4
    fig_caption: yes
    number_sections: yes
    fig_width: 3
    fig_height: 3
  word_document: 
    toc: yes
    toc_depth: 4
    fig_caption: yes
    keep_md: yes
editor_options: 
  chunk_output_type: inline
---

```{=html}
<style type="text/css">

/* Table of content - navigation */
div#TOC li {
    list-style:none;
    background-color:lightgray;
    background-image:none;
    background-repeat:none;
    background-position:0;
    font-family: Arial, Helvetica, sans-serif;
    color: #780c0c;
}


/* Title fonts */
h1.title {
  font-size: 24px;
  color: darkblue;
  text-align: center;
  font-family: Arial, Helvetica, sans-serif;
  font-variant-caps: normal;
}
h4.author { 
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  color: navy;
  text-align: center;
}
h4.date { 
  font-size: 18px;
  font-family: Arial, Helvetica, sans-serif;
  color: darkblue;
  text-align: center;
}

/* Section headers */
h1 {
    font-size: 22px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

h2 {
    font-size: 18px;
    font-family: "Times New Roman", Times, serif;
    color: navy;
    text-align: left;
}

h3 { 
    font-size: 15px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

h4 {
    font-size: 18px;
    font-family: "Times New Roman", Times, serif;
    color: darkred;
    text-align: left;
}

/* Decoration of hyperlinks  */

/* unvisited link */
a:link {
  color: green;
}

/* visited link */
a:visited {
  color: purple;
}

/* mouse over link */
a:hover {
  color: red;
}

/* selected link */
a:active {
  color: yellow;
}
</style>
```


```{r setup, include=FALSE}
# code chunk specifies whether the R code, warnings, and output 
# will be included in the output files.
options(repos = list(CRAN="http://cran.rstudio.com/"))
if (!require("tidyverse")) {
   install.packages("tidyverse")
   library(tidyverse)
}
if (!require("dplyr")) {
   install.packages("dplyr")
   library(dplyr)
}
if (!require("knitr")) {
   install.packages("knitr")
   library(knitr)
}
if (!require("cowplot")) {
   install.packages("cowplot")
   library(cowplot)
}
if (!require("latex2exp")) {
   install.packages("latex2exp")
   library(latex2exp)
}
if (!require("gapminder")) {
   install.packages("gapminder")
   library(gapminder)
}
if (!require("png")) {
    install.packages("png")             # Install png package
    library("png")
}
if (!require("RCurl")) {
    install.packages("RCurl")             # Install RCurl package
    library("RCurl")
}
if (!require("colourpicker")) {
    install.packages("colourpicker")              
    library("colourpicker")
}
if (!require("gganimate")) {
    install.packages("gganimate")              
    library("gganimate")
}
if (!require("gifski")) {
    install.packages("gifski")              
    library("gifski")
}
if (!require("magick")) {
    install.packages("magick")              
    library("magick")
}
if (!require("grDevices")) {
    install.packages("grDevices")              
    library("grDevices")
}
if (!require("jpeg")) {
    install.packages("jpeg")              
    library("jpeg")
}
if (!require("VGAM")) {
    install.packages("VGAM")              
    library("VGAM")
}
if (!require("MASS")) {
    install.packages("MASS")              
    library("MASS")
}
if (!require("nnet")) {
    install.packages("nnet")              
    library("nnet")
}
if (!require("cluster")) {
    install.packages("cluster")              
    library("cluster")
}
if (!require("stringr")) {
   install.packages("stringr", dependencies = TRUE)
   library(stringr)
}

if (!require("tm")) {
   install.packages("tm", dependencies = TRUE)
   library(tm)
}

if (!require("wordcloud")) {
   install.packages("wordcloud", dependencies = TRUE)
   library(wordcloud)
}

if (!require("RCurl")) {
   install.packages("RCurl", dependencies = TRUE)
   library(RCurl)
}

if (!require("XML")) {
   install.packages("XML", dependencies = TRUE)
   library(XML)
}
if (!require("SnowballC")) {
   install.packages("SnowballC", dependencies = TRUE)
   library(SnowballC)
}
if (!require("RColorBrewer")) {
   install.packages("RColorBrewer", dependencies = TRUE)
   library(RColorBrewer)
}
if (!require("ggplot2")) {
    install.packages("ggplot2")              
    library("ggplot2")
}
if (!require("gganimate")) {
    install.packages("gganimate")              
    library("gganimate")
}
if (!require("graphics")) {
    install.packages("graphics")              
    library("graphics")
}
if (!require("ggridges")) {
    install.packages("ggridges")              
    library("ggridges")
}
if (!require("plyr")) {
    install.packages("plyr")              
    library("plyr")
}
if (!require("ggiraph")) {
    install.packages("ggiraph")              
    library("ggiraph")
}
if (!require("highcharter")) {
    install.packages("highcharter")              
    library("highcharter")
}
if (!require("forecast")) {
    install.packages("forecast")              
    library("forecast")
}
if (!require("leaflet")) {
    install.packages("leaflet")              
    library("leaflet")
}
if (!require("maps")) {
    install.packages("maps")              
    library("maps")
}
if (!require("htmltools")) {
    install.packages("htmltools")              
    library("htmltools")
}
if (!require("htmlwidgets")) {
    install.packages("htmlwidgets")              
    library("htmlwidgets")
}
if (!require("leaflegend")) {
    install.packages("leaflegend")              
    library("leaflegend")
}
if (!require("geojsonio")) {
    install.packages("geojsonio")              
    library("geojsonio")
}
if (!require("stringi")) {
    install.packages("stringi")              
    library("stringi")
}
if (!require("RColorBrewer")) {
    install.packages("RColorBrewer")              
    library("RColorBrewer")
}
if (!require("tigris")) {
    install.packages("tigris")              
    library("tigris")
}
if (!require("leafpop")) {
    install.packages("leafpop")              
    library("leafpop")
}
if (!require("leafem")) {
    install.packages("leafem")              
    library("leafem")
}
if (!require("tmap")) {
    install.packages("tmap")              
    library("tmap")
}
if (!require("tmaptools")) {
    install.packages("tmaptools")              
    library("tmaptools")
}
if (!require("webshot2")) {
    install.packages("webshot2")              
    library("webshot2")
}
if (!require("sf")) {
    install.packages("sf")              
    library("sf")
}
if (!require("terra")) {
    install.packages("terra")              
    library("terra")
}
if (!require("leafpop")) {
    install.packages("leafpop")              
    library("leafpop")
}
if (!require("mapview")) {
    install.packages("mapview")              
    library("mapview")
}
if (!require("spData")) {
    install.packages("spData")              
    library("spData")
}
if(!require("animation")){
  install.packages("animation")
  library(animation)
}
if(!require("ggmap")){
  install.packages("ggmap")
  library(ggmap)
}
if(!require("htmlTable")){
  install.packages("htmlTable")
  library(htmlTable)
}
if(!require("magrittr")){
  install.packages("magrittr")
  library(magrittr)
}
if(!require("webshot")){
  install.packages("webshot")
  library(webshot)
}
if(!require("viridis")){
  install.packages("viridis")
  library(viridis)
}
if (!require("leafem")) {
    install.packages("leafem")
library("leafem")
}
if (!require("spDataLarge")) {
    install.packages("spDataLarge", repos = "https://geocompr.r-universe.dev")
library("spDataLarge")
}
if (!require("leaflet.extras")) {
    install.packages("leaflet.extras")
library("leaflet.extras")
}
if (!require("lattice")) {
    install.packages("lattice")
library("lattice")
}
if (!require("sp")) {
    install.packages("sp")
library("sp")
}
if (!require("pander")) {
    install.packages("pander")              
    library("pander")
}
if (!require("rlist")) {
    install.packages("rlist")              
    library("rlist")
}
if (!require("DT")) {
    install.packages("DT")              
    library("DT")
}
if (!require("crosstalk")) {
    install.packages("crosstalk")              
    library("crosstalk")
}
if (!require("Stat2Data")) {
   install.packages("Stat2Data")
   library(Stat2Data)
}

knitr::opts_chunk$set(echo = TRUE,       
                      warning = FALSE,   
                      result = TRUE,   
                      message = FALSE,
                      comment = NA)
```


```{r}
dat <- na.omit(read.csv(file="https://github.com/chinwex/STA553/raw/main/w09/PresidentialElection2000To2020.csv"))
dat$county_fips <- sprintf("%05d", dat$county_fips)
```

```{r}
votes = dat$candidatevotes
totalcountyvotes = dat$totalvotes
statedata <- dplyr::summarise(group_by(dat, year, state, state_po), sum.state = sum(candidatevotes))
totalstatevotes = statedata$sum.state

dat1 = dat
dat1$county_percent = (votes/totalcountyvotes)*100
dat1 = dat1[,-c(6,11,12)]

dat2 = dat %>%
  group_by(year, state, state_po, candidate, party) %>%
  dplyr::summarise(state_sum = sum(candidatevotes))

dat2 = dplyr::mutate(group_by(dat2, year, state, state_po), statetotal = sum(state_sum))
dat2$state_percent = ((dat2$state_sum)/dat2$statetotal)*100
```


```{r}

dat1final <- dat1 %>%
  group_by(year,state, county_name)%>%
  filter(county_percent == max(county_percent))

dat2final <- dat2 %>%
  group_by(year,state)%>%
  filter(state_percent == max(state_percent))
  

```


```{r}
write.csv(dat1final, file="C:\\Users\\echef\\Documents\\STA553\\week 9\\countysubset.csv")
write.csv(dat2final, file="C:\\Users\\echef\\Documents\\STA553\\week 9\\statesubset.csv")
```

\

<table border = 0 bordercolor="darkgreen" bgcolor='#f6f6f6'  width=100%  align = center>
<tr>
<td>
<div class='tableauPlaceholder' id='viz1712045546495' style='position: relative'>
<noscript><a href='#'><img alt='2000 to 2020 Presidential Election Results  ' src='https:&#47;&#47;public.tableau.com&#47;static&#47;images&#47;PH&#47;PHYS2KD6Y&#47;1_rss.png' style='border: none' />
</a>
</noscript>
<object class='tableauViz'  style='display:none;'>
<param name='host_url' value='https%3A%2F%2Fpublic.tableau.com%2F' /> 
<param name='embed_code_version' value='3' /> 
<param name='path' value='shared&#47;PHYS2KD6Y' /> 
<param name='toolbar' value='yes' />
<param name='static_image' value='https:&#47;&#47;public.tableau.com&#47;static&#47;images&#47;PH&#47;PHYS2KD6Y&#47;1.png' /> 
<param name='animate_transition' value='yes' />
<param name='display_static_image' value='yes' />
<param name='display_spinner' value='yes' />
<param name='display_overlay' value='yes' />
<param name='display_count' value='yes' />
<param name='language' value='en-GB' />
<param name='filter' value='publish=yes' />
</object>
</div>                
<script type='text/javascript'>                    
var divElement = document.getElementById('viz1712045546495');                    
var vizElement = divElement.getElementsByTagName('object')[0];                    
vizElement.style.width='100%';
vizElement.style.height=(divElement.offsetWidth*0.75)+'px';                    
var scriptElement = document.createElement('script');                    
scriptElement.src = 'https://public.tableau.com/javascripts/api/viz_v1.js';                    vizElement.parentNode.insertBefore(scriptElement, vizElement);                
</script>
</td>
</tr>
</table>


















