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 = { module.exports = {
site: 'toonamiaftermath.com', site: 'toonamiaftermath.com',
days: 2, days: 3,
async url({ channel, date }) { async url({ channel, date }) {
const playlists = await axios const playlists = await axios
.get( .get(
@ -20,16 +20,16 @@ module.exports = {
const playlist = playlists.find(p => date.isSame(p.startDate, 'day')) 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 }) { parser({ content, date }) {
let programs = [] let programs = []
const items = parseItems(content, date) const items = parseItems(content)
items.forEach(item => { items.forEach(item => {
programs.push({ programs.push({
title: item.name, title: item.name,
sub_title: item?.info?.episode, sub_title: parseEpisode(item),
icon: item?.info?.image, icon: parseIcon(item),
start: dayjs(item.startDate), start: dayjs(item.startDate),
stop: dayjs(item.endDate) stop: dayjs(item.endDate)
}) })
@ -39,16 +39,23 @@ module.exports = {
} }
} }
function parseItems(content, date) { function parseItems(content) {
if (!content) return [] if (!content) return []
const data = JSON.parse(content) const data = JSON.parse(content)
const blocks = data?.playlist?.blocks || [] if (!data || !data.playlist) return []
return blocks return data.playlist.blocks
.reduce((acc, curr) => { .reduce((acc, curr) => {
acc = acc.concat(curr.mediaList) acc = acc.concat(curr.mediaList)
return acc 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 return p
}) })
expect(results.length).toBe(17) expect(results.length).toBe(62)
expect(results[0]).toMatchObject({ expect(results[0]).toMatchObject({
start: '2022-11-29T17:00:30.231Z', start: '2022-11-29T17:00:30.231Z',
stop: '2022-11-29T17:20:54.031Z', stop: '2022-11-29T17:20:54.031Z',