Merge pull request #1724 from RevGear/toonami

Update toonamiaftermath.com.config.js
This commit is contained in:
LaneSh4d0w 2023-01-17 14:13:44 +01:00 committed by GitHub
commit e33be6d9fa
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 10 deletions

View file

@ -7,7 +7,7 @@ const API_ENDPOINT = `https://api.toonamiaftermath.com`
module.exports = {
site: 'toonamiaftermath.com',
days: 2,
days: 3,
async url({ channel, date }) {
const playlists = await axios
.get(
@ -20,16 +20,16 @@ module.exports = {
const playlist = playlists.find(p => date.isSame(p.startDate, 'day'))
return `https://api.toonamiaftermath.com/playlist?id=${playlist._id}&addInfo=true`
return `${API_ENDPOINT}/playlist?id=${playlist._id}&addInfo=true`
},
parser({ content, date }) {
let programs = []
const items = parseItems(content, date)
const items = parseItems(content)
items.forEach(item => {
programs.push({
title: item.name,
sub_title: item?.info?.episode,
icon: item?.info?.image,
sub_title: parseEpisode(item),
icon: parseIcon(item),
start: dayjs(item.startDate),
stop: dayjs(item.endDate)
})
@ -39,16 +39,23 @@ module.exports = {
}
}
function parseItems(content, date) {
function parseItems(content) {
if (!content) return []
const data = JSON.parse(content)
const blocks = data?.playlist?.blocks || []
if (!data || !data.playlist) return []
return blocks
return data.playlist.blocks
.reduce((acc, curr) => {
acc = acc.concat(curr.mediaList)
return acc
}, [])
.filter(i => date.isSame(i.startDate, 'day'))
}
function parseEpisode(item) {
return (item && item.info && item.info.episode) ? item.info.episode : null
}
function parseIcon(item) {
return (item && item.info && item.info.image) ? item.info.image : null
}

View file

@ -47,7 +47,7 @@ it('can parse response', () => {
return p
})
expect(results.length).toBe(17)
expect(results.length).toBe(62)
expect(results[0]).toMatchObject({
start: '2022-11-29T17:00:30.231Z',
stop: '2022-11-29T17:20:54.031Z',