Think you really know your taste in music? Let’s take a deeper dive into your favorite songs using the R wrapper “spotifyr” that pulls track information using Spotify’s Web API.

Most Recently Played

Let’s start off with something simple. What are your 5 most recently played songs?

Sound familiar?

Your Top Artists

Current Rankings

Now let’s learn more about the artists that you listen to the most. Are you a dedicated listener to your Top 3?

Your Favorite Genres

Here are your favorite genres based on your favorite artists.

Error in `group_by()`:
! Must group by variables found in `.data`.
✖ Column `genres` is not found.
Backtrace:
  1. ... %>% relocate(Ranking)
 10. dplyr:::group_by.data.frame(., genres)

Song Features

Spotify’s database includes many features of music tracks, including the loudness, tempo, danceability, and energy. Some of these variables, such as loudness and tempo, are easily quantifiable. Others, such as danceability and valence, are impossible to measure, yet these features exist. Properties of the audio are utilized in order to engineer features that are not measurable have a deterministic output. For instance, valence is an abstract feature that Spotify has defined as indicating the “positiveness” of the song. A valence closer to 1.0 indicates that the track is more cheerful.

Here’s some more information about the features made available by the Spotify API:

  • Danceability: How likely are you to party to the song? The algorithm to calculate the danceability score of a track takes into account the tempo and beat strength. A stronger, more regular beat correlates to a higher danceability score.

  • Energy: The intensity of a track.

  • Speechiness: A score based on the amount of spoken word in the song versus singing.

  • Acousticness: How likely the song was recorded acoustically.

  • Instrumentalness: How likely the song is an instrumental one. A song with more prominent vocals will score lower on the instrumentalness scale.

  • Liveness: How likely the song was recorded live.

  • Valence: The “positiveness” of the track. Songs that have happier tones will score highly in this feature.

Keeping these thoughts in mind, let’s compare the average track features for your Top 3 artists.

Emotion Map

Super cool, right? Let’s take it a step further and classify individual songs from your favorite artists based on their emotional content. The next figure is based on Russell’s Circumplex Model of Emotion, which takes a 2D approach to display emotional categories based on the relationship between arousal and valence. Music emotion recognition (MER) is an important part of research when it comes to music information retrieval, and recommender systems, such those used for Spotify, rely on many different features in order to detect emotion in tracks and make similar suggestions. We will create a figure based on Russell’s Model that maps all tracks from your Top 3 into four different emotional quadrants: Happy, Angry, Sad, and Relaxed.

Take a moment to check out which tracks are in each category. Do you agree with the results? Your Top 3 artists collectively have 148 tracks categorized as angry, 83 as happy, 28 as sad, and 20 as relaxed. You’re into some pretty angry music!

Let’s do some quick calculations.

Looks like Panic! At The Disco is your Angriest Artist! Panic! At The Disco has the greatest number of songs in their discography categorized as angry based on the energy to valence ratio of the tracks compared to your other two top artists.

Sentiment Analysis

Let’s use the package geniusr to interact with the Genius API to identify the dominant sentiment present in the songs of your favorite artists. We will use the tidytext package to analyze the sentiment of the lyrics by identifying the sentiment content of the individual words. The general-purpose lexicon utilized to identify emotions is called bing, which contains thousands of words that are assigned emotions such as joy, anger, anticipation, and sadness. We will analyze the sentiment in the most recent album of your top artist from the past month.


Attaching package: ‘gridExtra’

The following object is masked from ‘package:dplyr’:

    combine

Recommendations

A special playlist curated just for you has been uploaded to your Spotify account. Happy listening!

---
title: "Data Visualization with Spotify"
output:
  html_notebook
---

Think you really know your taste in music? Let's take a deeper dive into your
favorite songs using the R wrapper "spotifyr" that pulls track information using
[Spotify's Web API](https://developer.spotify.com/documentation/web-api/). 

```{r setup, include=FALSE}
knitr::opts_chunk$set(warning = FALSE, message = FALSE) 
#https://latinmusichistory.github.io/index.html
#install.packages("formattable")
```

```{r echo=FALSE}
library(spotifyr)
library(httr)
library(dplyr)
library(purrr) 
library(knitr)
library(lubridate)
```

```{r include=FALSE}
# browseURL(paste0('https://accounts.spotify.com/authorize?client_id=f676fa7eaf0e4f79a3442a4e25d540ee','&response_type=code&redirect_uri=', 'http://localhost:1410/','/&scope=user-read-recently-played'),browser = getOption("browser"), encodeIfNeeded = FALSE)
#     
#     #construct body of POST request FIRST TIME
#     request_body <- list(grant_type='authorization_code',
#                          redirect_uri='http://localhost:1410/', #input your domain name
#                          client_id = 'f676fa7eaf0e4f79a3442a4e25d540ee', #input your Spotify Client ID
#                          client_secret ='bf59ac0268a34c75bba1707b7bc0ea7b') #input your Spotify Client Secret
#     
#     #get user tokens FIRST TIME
#     access_token <- httr::content(httr::POST('https://accounts.spotify.com/api/token',
#                                            body=request_body,
#                                            encode='form'))

# response = POST(
#   'https://accounts.spotify.com/api/token',
#   accept_json(),
#   authenticate('f676fa7eaf0e4f79a3442a4e25d540ee', 'bf59ac0268a34c75bba1707b7bc0ea7b'),
#   body = list(grant_type = 'client_credentials'),
#   encode = 'form',
#   verbose()
# )
# 
# access_token = content(response)$access_token
```


```{r echo=FALSE}
Sys.setenv(SPOTIFY_CLIENT_ID = 'f676fa7eaf0e4f79a3442a4e25d540ee')
Sys.setenv(SPOTIFY_CLIENT_SECRET = 'bf59ac0268a34c75bba1707b7bc0ea7b')

access_token <- get_spotify_access_token()
```

```{r echo=FALSE}
Sys.setenv(GENIUS_CLIENT_ID = 'zp3hhwiVEVzGO6HAoR1k_dcDu2rP_Y6k2UOJW1quNRlvktFeJdksZ2qCpW5K0pwD')
Sys.setenv(GENIUS_CLIENT_SECRET =
             'E-Bf9GegKNOPjC5ejzZm4XYfVn9dAK3VHkJV1LV-ujZKQF-3YF_X4nRVKMToH6wkPmDZ35BUmx4oFZN9qPqRrg')
```


## Most Recently Played
Let's start off with something simple. What are your 5 most recently played 
songs?
```{r echo=FALSE}
library(formattable)
mostRecentlyPlayed <- get_my_recently_played(limit = 5) %>% 
    mutate(artist.name = map_chr(track.artists, function(x) x$name[1]),
           played_at = as_datetime(played_at))
mostRecentlyPlayedUri <- strsplit(mostRecentlyPlayed$track.uri, split = ":")

toPlay <- matrix(unlist(mostRecentlyPlayedUri), ncol=3, byrow=TRUE)
mostRecentlyPlayed <- mostRecentlyPlayed %>%
  select(track.name, artist.name) %>%
  rename(Track = track.name, Artist = artist.name)
formattable(mostRecentlyPlayed, 
            align = c("l", "l"))
```

Sound familiar?
```{css, echo=FALSE}
.box { display:inline-block; margin-left:70px; margin-right:70px }
```

```{=html}
<div align="center" class="box">
<iframe src="https://open.spotify.com/embed/track/`r toPlay[1,3]`" frameBorder="0" allowtransparency="true" allow="encrypted-media" data-external="1"></iframe>
</div>
<div align="center" class="box">
<iframe src="https://open.spotify.com/embed/track/`r toPlay[2,3]`" frameBorder="0" allowtransparency="true" allow="encrypted-media" data-external="1"></iframe>
</div>
```

## Your Top Artists
#### Current Rankings
Now let's learn more about the artists that you listen to the most. Are you a dedicated listener to your Top 3?
```{r echo=FALSE}
getRankings <- function(time) {
  as.data.frame(get_my_top_artists_or_tracks(
  type = "artists",
  limit = 10,
  offset = 0,
  time_range = time,
  authorization = get_spotify_authorization_code(),
  include_meta_info = FALSE
)$name)
}

getIDs <- function(time) {
  as.data.frame(get_my_top_artists_or_tracks(
  type = "artists",
  limit = 10,
  offset = 0,
  time_range = time,
  authorization = get_spotify_authorization_code(),
  include_meta_info = FALSE
)$id)
}

top10ArtistsNow <- getRankings("short_term")
colnames(top10ArtistsNow) <- c("Past Month")
top10ArtistsNow <- top10ArtistsNow %>%
  mutate(Ranking=row_number()) %>%
  relocate(Ranking)

top10Artists6mo <- getRankings("medium_term")
colnames(top10Artists6mo) <- c("Past 6 Months")
top10Artists6mo <- top10Artists6mo %>%
  mutate(Ranking=row_number()) %>%
  relocate(Ranking)

top10ArtistsEver <- getRankings("long_term")
colnames(top10ArtistsEver) <- c("All Time")
top10ArtistsEver <- top10ArtistsEver %>%
  mutate(Ranking=row_number()) %>%
  relocate(Ranking)

top10ArtistsEver <- top10ArtistsEver %>%
  left_join(top10Artists6mo, by = c("Ranking")) %>%
  left_join(top10ArtistsNow, by = c("Ranking")) 
```


```{r echo=FALSE}
library(formattable)
formattable(top10ArtistsEver, 
            align = c("c", "c", "c", "c"),
            list(
   `All Time` = formatter("span", 
                          style = x ~ ifelse(x == top10ArtistsEver[2][1,1], 
                                                     style(color = "blue", font.weight = "bold"),
                                                     ifelse(x == top10ArtistsEver[2][2,1], 
                                                            style(color = "brown", font.weight = "bold"), 
                                                            ifelse(x == top10ArtistsEver[2][3,1], 
                                                                   style(color = "green", font.weight ="bold"),
                                                                   NA)))
                          ),
   `Past 6 Months` = formatter("span", 
                          style = x ~ ifelse(x == top10ArtistsEver[2][1,1], 
                                                     style(color = "blue", font.weight = "bold"),
                                                     ifelse(x == top10ArtistsEver[2][2,1], 
                                                            style(color = "brown", font.weight = "bold"), 
                                                            ifelse(x == top10ArtistsEver[2][3,1], 
                                                                   style(color = "green", font.weight ="bold"),
                                                                   NA)))
                          ),
   `Past Month` = formatter("span", 
                          style = x ~ ifelse(x == top10ArtistsEver[2][1,1], 
                                                     style(color = "blue", font.weight = "bold"),
                                                     ifelse(x == top10ArtistsEver[2][2,1], 
                                                            style(color = "brown", font.weight = "bold"), 
                                                            ifelse(x == top10ArtistsEver[2][3,1], 
                                                                   style(color = "green", font.weight ="bold"),
                                                                   NA)))
                          )
))
```

#### Your Favorite Genres
Here are your favorite genres based on your favorite artists.
```{r echo=FALSE}
idsNow <- getIDs("short_term")
ids6mo <- getIDs("medium_term")
idsEver <- getIDs("long_term")

ids <- rbind(idsNow, ids6mo, idsEver)
ids <- distinct(ids)
colnames(ids) <- c("artist_id")

genres <- c()
for (i in 1:length(ids$artist_id)) {
  info <- spotifyr::get_artist(id = ids$artist_id[i], authorization = get_spotify_access_token())
  genres <- c(genres, info$genres)
}
genres <- as.data.frame(genres)
genres <- genres %>%
  group_by(genres) %>%
  summarize(count = n()) %>%
  arrange(desc(count)) %>%
  slice(1:5) %>%
  select(genres) %>%
  rename(Genre = genres) %>%
  mutate(Ranking = row_number()) %>%
  relocate(Ranking)
formattable(genres, align = c("l", "l")) 
```

#### Song Features
```{r echo=FALSE}
topArtist <- get_my_top_artists_or_tracks(
  type = "artists",
  limit = 20,
  offset = 0,
  time_range = "long_term",
  authorization = get_spotify_authorization_code(),
  include_meta_info = FALSE
) %>% 
  slice(1:3)
topArtistUri1 <- strsplit(topArtist$uri, split = ":")[[1]][3]
topArtistUri2 <- strsplit(topArtist$uri, split = ":")[[2]][3]
topArtistUri3 <- strsplit(topArtist$uri, split = ":")[[3]][3]
```

```{r include=FALSE}
createTrackInfo <- function(artist_uri) {
   topArtistTrackInfo <- get_artist_audio_features(
    artist = artist_uri,
    include_groups = "album",
    return_closest_artist = TRUE,
    dedupe_albums = TRUE,
    market = NULL,
    authorization = get_spotify_access_token()
  )
  
  topArtistTrackInfo <- topArtistTrackInfo %>%
    select(artist_name, danceability, energy, key, loudness, speechiness, 
           acousticness, instrumentalness, liveness, valence, tempo, track_id, 
           track_name, album_name, key_name, duration_ms) %>%
    distinct(track_name, .keep_all = TRUE)
  return(topArtistTrackInfo)
}

firstArtist <- createTrackInfo(topArtistUri1)
secondArtist <- createTrackInfo(topArtistUri2)
thirdArtist <- createTrackInfo(topArtistUri3)

top3 <- rbind(firstArtist, secondArtist, thirdArtist)
```

Spotify's database includes many features of music tracks, including 
the loudness, tempo, danceability, and energy. Some of these variables, such as
loudness and tempo, are easily quantifiable. Others, such as danceability and
valence, are impossible to measure, yet these features exist. Properties of the 
audio are utilized in order to engineer features that are not measurable have 
a deterministic output. For instance, valence is an abstract feature that Spotify
has defined as indicating the "positiveness" of the song. A valence closer to 1.0
indicates that the track is more cheerful. 

Here's some more information about the features made available by the Spotify API:

* **Danceability:** How likely are you to party to the song? The algorithm to calculate the danceability score of a track takes into account the tempo and beat strength. A stronger, more regular beat correlates to a higher danceability score.

* **Energy:** The intensity of a track.

* **Speechiness:** A score based on the amount of spoken word in the song versus singing.

* **Acousticness:** How likely the song was recorded acoustically.

* **Instrumentalness:** How likely the song is an instrumental one. A song with more prominent vocals will score lower on the instrumentalness scale.

* **Liveness:** How likely the song was recorded live.

* **Valence:** The "positiveness" of the track. Songs that have happier tones will score highly in this feature.

Keeping these thoughts in mind, let's compare the average track features for your Top 3 artists. 

```{r echo=FALSE}
# Noah Kahan, Bleachers, Hozier
library(fmsb)
library(colormap)
max_min <- data.frame(
  danceability = c(1, 0), energy = c(1, 0),
  speechiness = c(1, 0), acousticness = c(1, 0), instrumentalness = c(1, 0),
  liveness = c(1, 0), valence = c(1, 0)
)
rownames(max_min) <- c("Max", "Min")

meanTrackFeatures <- top3 %>%
  select(-track_id, -track_name, -album_name, -key_name, -key, -loudness, -tempo, -duration_ms) %>%
  group_by(artist_name) %>%
  summarise_all("mean")

top3Names <- top3 %>%
  group_by(artist_name) %>%
  summarize(n = n())

meanTrackFeatures1 <- meanTrackFeatures
rownames(meanTrackFeatures) <- meanTrackFeatures$artist_name
meanTrackFeatures$artist_name <- NULL
meanTrackFeatures <- rbind(max_min, meanTrackFeatures)

create_radarchart <- function(data, color = "#00AFBB", 
                                        vlabels = colnames(data), vlcex = 0.5,
                                        caxislabels = NULL, title = NULL, ...){
  radarchart(
    data, axistype = 1,
    # Customize the polygon
    pcol = color, pfcol = scales::alpha(color, 0.4), plwd = 2, plty = 1,
    # Customize the grid
    cglcol = "grey", cglty = 1, cglwd = 0.8,
    # Customize the axis
    axislabcol = "grey", 
    # Variable labels
    vlcex = vlcex, vlabels = vlabels,
    caxislabels = caxislabels, title = title, ...
  )
}

# Define colors and titles
colors <- c("#00AFBB", "#E7B800", "#FC4E07")
titles <- c(top3Names$artist_name[1], top3Names$artist_name[2], top3Names$artist_name[3])

# Reduce plot margin using par()
# Split the screen in 3 parts
op <- par(mar = c(1, 1, 1, 1))
par(mfrow = c(2,2))

#colors_border=colormap(colormap=colormaps$viridis, nshades=6, alpha=1)
#colors_in=colormap(colormap=colormaps$viridis, nshades=6, alpha=0.3)

# Create the radar chart
for(i in 1:3) {
  create_radarchart(
    data = meanTrackFeatures[c(1, 2, i+2), ], caxislabels = c(0, 0.25, 0.50, 0.75, 1.0),
    color = colors[i], title = titles[i]
    )
}
create_radarchart(
  data = meanTrackFeatures, caxislabels = c(0, 0.25, 0.50, 0.75, 1.0),
  color = c("#00AFBB", "#E7B800", "#FC4E07"),
  title = "All 3 Artists"
)

par(op)
```
#### Emotion Map
Super cool, right? Let's take it a step further and classify individual songs 
from your favorite artists based on their emotional content. The next figure is based 
on [Russell’s Circumplex Model of Emotion](https://www.researchgate.net/figure/Russells-circumplex-model-13_fig5_307909024),
which takes a 2D approach to display emotional categories based on the relationship
between arousal and valence. Music emotion recognition (MER) is an important part
of research when it comes to music information retrieval, and recommender systems,
such those used for Spotify, rely on many different features in order to detect 
emotion in tracks and make similar suggestions. We will create a figure based on
Russell's Model that maps all tracks from your Top 3 into four different emotional
quadrants: Happy, Angry, Sad, and Relaxed.

```{r echo=FALSE}
library(ggplot2)
library(plotly)
library(htmlwidgets)
emotionalQuadrant <- ggplot(data = top3, 
                            aes(x = valence, y = energy, color = artist_name,
                                text = paste("Song:", track_name, "\nArtist:", artist_name,
                                             "\nEnergy:", energy, "\nValence:", valence))) +
  geom_jitter() +
  geom_vline(xintercept = 0.5) +
  geom_hline(yintercept = 0.5) +
  scale_x_continuous(expand = c(0, 0), limits = c(0, 1)) +
  scale_y_continuous(expand = c(0, 0), limits = c(0, 1)) +
  annotate('text', 0.25 / 2, 0.95, label = "Angry / Tense") +
  annotate('text', 1.75 / 2, 0.95, label = "Happy / Joyful") +
  annotate('text', 1.75 / 2, 0.05, label = "Relaxed / Calm") +
  annotate('text', 0.25 / 2, 0.05, label = "Sad / Depressing") +
  labs(x = "Valence", y = "Energy", color = "Artist Name") +
  ggtitle("Music Emotion Map for Your Top 3 Artists of All Time", "Based on Energy and Valence")  

quad <- ggplotly(emotionalQuadrant, tooltip = "text")
```

```{r echo=FALSE}
htmlwidgets::saveWidget(quad, "index.html")

htmltools::tags$iframe(
  src=file.path(getwd(), "index.html"),
  width="100%",
  height="600",
  scrolling="no",
  seamless="seamless",
  frameBorder="0"
)

```

```{r include=FALSE}
quadrant_num <- c(1, 2, 3, 4)
name <- c("happy", "angry", "sad", "relaxed")
df <- data.frame(quadrant_num, name)

quadrants <- top3 %>%
  select(artist_name, energy, valence) %>%
  mutate(quadrant = ifelse(energy >= 0.5 & valence >= 0.5, 1, 
                           ifelse(energy >= 0.5 & valence < 0.5, 2,
                                  ifelse(energy < 0.5 & valence < 0.5, 3, 4)))) %>%
  group_by(quadrant) %>%
  summarize(quadrant_count = n()) %>%
  left_join(df, by = c("quadrant" = "quadrant_num")) %>%
  arrange(desc(quadrant_count))

topEmotion <- quadrants %>%
  slice(1)
topEmotion
```
Take a moment to check out which tracks are in each category. Do you agree with the results?
Your Top 3 artists collectively have `r quadrants$quadrant_count[1]` tracks categorized as
`r quadrants$name[1]`, `r quadrants$quadrant_count[2]` as `r quadrants$name[2]`, 
`r quadrants$quadrant_count[3]` as `r quadrants$name[3]`, and 
`r quadrants$quadrant_count[4]` as `r quadrants$name[4]`. You're into some pretty
`r topEmotion$name[1]` music!

```{r include=FALSE}
titleEmotion <- ifelse(topEmotion$name[1] == "happy", "Happiest",
                       ifelse(topEmotion$name[1] == "angry", "Angriest",
                              ifelse(topEmotion$name[1] == "sad", "Saddest", "Most Relaxed")))
titleEmotion
```

Let's do some quick calculations.
```{r echo=FALSE}
songCount <- top3 %>%
  group_by(artist_name) %>%
  summarize(totalSongCount = n())

percentage <- top3 %>%
  select(artist_name, energy, valence, duration_ms) %>%
  mutate(quadrant = ifelse(energy >= 0.5 & valence >= 0.5, 1, 
                           ifelse(energy >= 0.5 & valence < 0.5, 2,
                                  ifelse(energy < 0.5 & valence < 0.5, 3, 4)))) %>%
  filter(quadrant %in% c(topEmotion$quadrant[1])) %>%
  group_by(artist_name) %>%
  summarize(count = n()) %>%
  left_join(songCount, by = c("artist_name")) %>%
  mutate(percInQuad = (count / totalSongCount) * 100) %>%
  arrange(desc(percInQuad)) %>%
  select(artist_name, percInQuad) %>%
  rename("Artist Name" = artist_name, "Percent of all Songs in Top Quadrant" = percInQuad)

formattable(percentage, 
            align = c("l", "l"))

artist <- percentage$`Artist Name`[1]
```
Looks like **`r artist`** is your `r titleEmotion` Artist! `r artist` has the greatest
number of songs in their discography categorized as `r topEmotion$name[1]` based on
the energy to valence ratio of the tracks compared to your other two top artists.  

#### Sentiment Analysis
Let's use the package *geniusr* to interact with the [Genius API](https://docs.genius.com)
to identify the dominant sentiment present in the songs of your favorite artists. We will
use the *tidytext* package to analyze the sentiment of the lyrics by identifying the 
sentiment content of the individual words. The general-purpose lexicon utilized to identify
emotions is called *bing*, which contains thousands of words that are assigned emotions such
as joy, anger, anticipation, and sadness. We will analyze the sentiment in the most recent
album of your top artist from the past month. 

```{r include=FALSE}
library(geniusr)

genius_access_token = "UxsyjRkyaVaW6pfxbw24r3CJ_LbmQ0a4YpcqyJqmgMhybhBTa5pQNK-TV3lcx_pu"

popularArtistId <- search_spotify(
  q = top10ArtistsEver$`Past Month`[1],
  type = c("artist"),
  market = NULL,
  limit = 1,
  offset = 0,
  include_external = NULL,
  authorization = get_spotify_access_token(),
  include_meta_info = FALSE)$id

album <- get_artist_albums(
  id = popularArtistId,
  include_groups = c("album", "single"),
  market = "US",
  limit = 20,
  offset = 0,
  authorization = get_spotify_access_token(),
  include_meta_info = FALSE)

tracks <- get_album_tracks(
  id = album$id[1],
  limit = 20,
  offset = 0,
  market = NULL,
  authorization = get_spotify_access_token(),
  include_meta_info = FALSE)

artist_id <- search_artist(top10ArtistsEver$`Past Month`[1], n_results = 10, access_token = genius_access_token)$artist_id[1]

songs <- get_artist_songs_df(
  artist_id,
  sort = c("title", "popularity"),
  include_features = FALSE,
  access_token = genius_access_token)

songsFinal <- songs %>%
  inner_join(tracks, by = c("song_name" = "name")) %>%
  select(song_id, id, song_name, duration_ms, song_lyrics_url) %>%
  rename(genius_id = song_id, spotify_id = id)
```

```{r include=FALSE}
lyrics <- c()
for (i in 1:15) {
  #for (i in 1:length(songsFinal$song_name)) {
  current <- get_lyrics_id(songsFinal$genius_id[i], access_token = genius_access_token)
  #print(current)
  current <- current %>%
    select(line, song_name)
  print(current)
  if (is.na(current$line[1])) {
    next
  } else {
    lyrics <- rbind(lyrics, current)
  }
}
lyrics
```

```{r include=FALSE}
library(tidytext)
library(textdata)

nrc <- get_sentiments("nrc")
bing <- get_sentiments("bing")
```

```{r echo=FALSE}
library(forcats)
tokenized <- lyrics %>%
  unnest_tokens(word, line)

nrc_sentiments <- nrc %>%
  filter(!sentiment %in% c("positive", "negative")) 

top3Sentiments <- tokenized %>%
  inner_join(nrc_sentiments, by = c("word")) %>%
  group_by(sentiment) %>%
  summarize(count = n()) %>%
  arrange(desc(count)) %>%
  slice(1:3)

makeGraphs <- function(i) {
  
}

library(gridExtra)
library(grid)
library(ggplot2)
library(lattice)
plots <- list()

for (i in 1:3) {
  nam <- paste("A", i, sep = "")
  p <- tokenized %>%
    inner_join(nrc_sentiments, by = c("word")) %>%
    filter(sentiment %in% c(top3Sentiments$sentiment[i])) %>%
    group_by(song_name) %>%
    summarize(count = n()) %>%
    arrange(count) %>% 
    ungroup() %>%
    ggplot(aes(count, fct_inorder(song_name))) +
      geom_col() +
      scale_fill_viridis_d() +
      labs(x = "Count",
           y = "Songs",
           title = paste("Counts of words with", top3Sentiments$sentiment[i], "sentiment\n in tracks from",
                         album$name, sep = " ", collapse = NULL)) + 
    theme(plot.title = element_text(size=8)) +
    theme(plot.title = element_text(hjust = 0.5)) +
    theme(axis.text = element_text(size = 8)) +
    theme(axis.title = element_text(size = 8))  
  assign(nam, p)
}
grid.arrange(A1, A2, A3, nrow = 2)
```

#### Recommendations
A special playlist curated just for you has been uploaded to your Spotify account.
Happy listening!

```{r include=FALSE}
topTracks <- get_my_top_artists_or_tracks(
  type = "tracks",
  limit = 25,
  offset = 0,
  time_range = "medium_term",
  authorization = get_spotify_authorization_code(),
  include_meta_info = FALSE)

recs <- get_recommendations_all(track_ids = topTracks$id)
myID <- get_my_profile(authorization = get_spotify_authorization_code())$id

playlistID <- create_playlist(
  user_id = myID,
  name = "A special playlist just for you!",
  public = TRUE,
  collaborative = FALSE,
  description = "Happy listening! <3 Angela",
  authorization = get_spotify_authorization_code())$id

add_tracks_to_playlist(
  playlist_id = playlistID,
  uris = recs$id,
  position = NULL,
  authorization = get_spotify_authorization_code())
```


```{r include=FALSE}
#Sources
#https://msmith7161.github.io/what-is-speechiness/
#https://www.datanovia.com/en/blog/beautiful-radar-chart-in-r-using-fmsb-and-ggplot-packages/
#https://www8.gsb.columbia.edu/articles/projects/what-makes-a-hit/
#https://intro2r.com/r-markdown-anatomy.html
#https://www.data-to-viz.com/caveat/spider.html
#https://s3.amazonaws.com/udacity-hosted-downloads/ud651/GeographyOfAmericanMusic.html
#https://www.rstudio.com/blog/r-markdown-tips-tricks-4-looks-better-works-better/
#https://towardsdatascience.com/explore-your-activity-on-spotify-with-r-and-spotifyr-how-to-analyze-and-visualize-your-stream-dee41cb63526
#https://eden.dei.uc.pt/~ruipedro/publications/Conferences/SMC_2021_Panda.pdf
#https://towardsdatascience.com/explore-your-activity-on-spotify-with-r-and-spotifyr-how-to-analyze-and-visualize-your-stream-dee41cb63526
#https://ieeexplore.ieee.org/abstract/document/9823535/figures#figures
#https://link.springer.com/chapter/10.1007/978-3-319-45378-1_60
#https://www.ncbi.nlm.nih.gov/pmc/articles/PMC8860518/
#https://medium.com/mcd-unison/using-the-httr-package-in-r-to-get-audio-features-from-spotify-api-68587262b2c7
#https://www.tidytextmining.com/sentiment.html
```


















