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.
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
```


















