chore: now -> tv grouping post
This commit is contained in:
parent
0451188003
commit
dc3c878386
1 changed files with 102 additions and 0 deletions
102
src/posts/2023/now-page-grouping-episodes-of-same-show.md
Normal file
102
src/posts/2023/now-page-grouping-episodes-of-same-show.md
Normal file
|
@ -0,0 +1,102 @@
|
||||||
|
---
|
||||||
|
date: "2023-09-06"
|
||||||
|
title: "Now page: grouping episodes of the same tv show"
|
||||||
|
draft: false
|
||||||
|
tags:
|
||||||
|
- JavaScript
|
||||||
|
- Eleventy
|
||||||
|
- development
|
||||||
|
image: https://cdn.coryd.dev/blog/grouped-tv.jpg
|
||||||
|
---
|
||||||
|
I made a minor update to how I'm normalizing TV data for display on my now page.<!-- excerpt -->
|
||||||
|
|
||||||
|
By *minor* I mean one of those things that may well break inexplicably depending on where the data lands. Instead of returning a normalized array based directly off the data returned by [Trakt](https://trakt.tv)'s API I'm instead collecting episodes in an array, checking as I iterate through the response to see if an episode of the same show exists and replacing that object with a mutated object designed to display the range of episodes watched for the show.
|
||||||
|
|
||||||
|
{% image 'https://cdn.coryd.dev/blog/grouped-tv.jpg', 'Grouped TV episodes', 'w-full', '600px' %}
|
||||||
|
|
||||||
|
{% raw %}
|
||||||
|
```javascript
|
||||||
|
const EleventyFetch = require('@11ty/eleventy-fetch')
|
||||||
|
|
||||||
|
module.exports = async function () {
|
||||||
|
const TV_KEY = process.env.API_KEY_TRAKT
|
||||||
|
const url = 'https://api.trakt.tv/users/cdransf/history/shows'
|
||||||
|
const res = EleventyFetch(url, {
|
||||||
|
duration: '1h',
|
||||||
|
type: 'json',
|
||||||
|
fetchOptions: {
|
||||||
|
headers: {
|
||||||
|
'Content-Type': 'application/json',
|
||||||
|
'trakt-api-version': 2,
|
||||||
|
'trakt-api-key': TV_KEY,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}).catch()
|
||||||
|
const data = await res
|
||||||
|
const episodes = []
|
||||||
|
data.reverse().forEach((episode) => {
|
||||||
|
const episodeNumber = episode['episode']['number']
|
||||||
|
const seasonNumber = episode['episode']['season']
|
||||||
|
|
||||||
|
if (episodes.find((e) => e.name === episode?.['show']?.['title'])) {
|
||||||
|
// cache the matched episode reference
|
||||||
|
const matchedEpisode = episodes.find((e) => e.name === episode?.['show']?.['title'])
|
||||||
|
|
||||||
|
// remove the matched episode from the array
|
||||||
|
episodes.splice(
|
||||||
|
episodes.findIndex((e) => e.name === episode['show']['title']),
|
||||||
|
1
|
||||||
|
)
|
||||||
|
|
||||||
|
// populate the subtext to show the appropriate range if it spans multiple seasons
|
||||||
|
// this yields a string in the format of S1E1 - S2E2 or S1E1 - E2
|
||||||
|
const subtext =
|
||||||
|
matchedEpisode['season'] === episode['episode']['season']
|
||||||
|
? `S${matchedEpisode['startingSeason'] || matchedEpisode['season']}E${
|
||||||
|
matchedEpisode['startingEpisode'] || matchedEpisode['episode']
|
||||||
|
} - E${episode['episode']['number']}`
|
||||||
|
: `S${matchedEpisode['startingSeason'] || matchedEpisode['season']}E${
|
||||||
|
matchedEpisode['startingEpisode'] || matchedEpisode['episode']
|
||||||
|
} - S${episode['episode']['season']}E${episode['episode']['number']}`
|
||||||
|
|
||||||
|
// push the new episode to the array
|
||||||
|
episodes.push({
|
||||||
|
name: matchedEpisode['name'],
|
||||||
|
title: matchedEpisode['title'],
|
||||||
|
url: `https://trakt.tv/shows/${episode['show']['ids']['slug']}`,
|
||||||
|
subtext,
|
||||||
|
image:
|
||||||
|
`https://cdn.coryd.dev/tv/${matchedEpisode['name']
|
||||||
|
.replace(':', '')
|
||||||
|
.replace(/\s+/g, '-')
|
||||||
|
.toLowerCase()}.jpg` || 'https://cdn.coryd.dev/tv/missing-tv.jpg',
|
||||||
|
startingEpisode: matchedEpisode['episode'],
|
||||||
|
startingSeason: matchedEpisode['season'],
|
||||||
|
episode: episodeNumber,
|
||||||
|
season: seasonNumber,
|
||||||
|
type: 'tv-range',
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
// if an episode with the same show name doesn't exist, push it to the array
|
||||||
|
episodes.push({
|
||||||
|
name: episode['show']['title'],
|
||||||
|
title: episode['episode']['title'],
|
||||||
|
url: `https://trakt.tv/shows/${episode['show']['ids']['slug']}/seasons/${episode['episode']['season']}/episodes/${episode['episode']['number']}`,
|
||||||
|
subtext: `${episode['show']['title']} • S${episode['episode']['season']}E${episode['episode']['number']}`,
|
||||||
|
image:
|
||||||
|
`https://cdn.coryd.dev/tv/${episode['show']['title']
|
||||||
|
.replace(':', '')
|
||||||
|
.replace(/\s+/g, '-')
|
||||||
|
.toLowerCase()}.jpg` || 'https://cdn.coryd.dev/tv/missing-tv.jpg',
|
||||||
|
episode: episodeNumber,
|
||||||
|
season: seasonNumber,
|
||||||
|
type: 'tv',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
// return a reverse sorted array of episodes to match the watch order
|
||||||
|
return episodes.reverse()
|
||||||
|
}
|
||||||
|
```
|
||||||
|
{% endraw %}
|
Reference in a new issue