Fixes linter errors

This commit is contained in:
freearhey
2023-10-15 14:08:23 +03:00
parent 57e508fc3b
commit 63c86a2b30
393 changed files with 28447 additions and 28443 deletions

View File

@@ -1,82 +1,82 @@
const axios = require('axios')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
const timezone = require('dayjs/plugin/timezone')
dayjs.extend(utc)
dayjs.extend(timezone)
const API_ENDPOINT = 'https://content-api.mytvsuper.com/v1'
module.exports = {
site: 'mytvsuper.com',
days: 2,
request: {
cache: {
ttl: 60 * 60 * 1000 // 1h
}
},
url: function ({ channel, date }) {
return `${API_ENDPOINT}/epg?network_code=${channel.site_id}&from=${date.format(
'YYYYMMDD'
)}&to=${date.format('YYYYMMDD')}&platform=web`
},
parser({ content, channel, date }) {
const programs = []
const items = parseItems(content, date)
for (let item of items) {
const prev = programs[programs.length - 1]
const start = parseStart(item)
const stop = start.add(30, 'm')
if (prev) {
prev.stop = start
}
programs.push({
title: parseTitle(item, channel),
description: parseDescription(item, channel),
episode: parseInt(item.episode_no),
start: start,
stop: stop
})
}
return programs
},
async channels({ lang }) {
const data = await axios
.get(`${API_ENDPOINT}/channel/list?platform=web`)
.then(r => r.data)
.catch(console.error)
return data.channels.map(c => {
const name = lang === 'en' ? c.name_en : c.name_tc
return {
site_id: c.network_code,
name,
lang
}
})
}
}
function parseTitle(item, channel) {
return channel.lang === 'en' ? item.programme_title_en : item.programme_title_tc
}
function parseDescription(item, channel) {
return channel.lang === 'en' ? item.episode_synopsis_en : item.episode_synopsis_tc
}
function parseStart(item) {
return dayjs.tz(item.start_datetime, 'Asia/Hong_Kong')
}
function parseItems(content, date) {
const data = JSON.parse(content)
if (!Array.isArray(data) || !data.length || !Array.isArray(data[0].item)) return []
const dayData = data[0].item.find(i => i.date === date.format('YYYY-MM-DD'))
if (!dayData || !Array.isArray(dayData.epg)) return []
return dayData.epg
}
const axios = require('axios')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
const timezone = require('dayjs/plugin/timezone')
dayjs.extend(utc)
dayjs.extend(timezone)
const API_ENDPOINT = 'https://content-api.mytvsuper.com/v1'
module.exports = {
site: 'mytvsuper.com',
days: 2,
request: {
cache: {
ttl: 60 * 60 * 1000 // 1h
}
},
url: function ({ channel, date }) {
return `${API_ENDPOINT}/epg?network_code=${channel.site_id}&from=${date.format(
'YYYYMMDD'
)}&to=${date.format('YYYYMMDD')}&platform=web`
},
parser({ content, channel, date }) {
const programs = []
const items = parseItems(content, date)
for (let item of items) {
const prev = programs[programs.length - 1]
const start = parseStart(item)
const stop = start.add(30, 'm')
if (prev) {
prev.stop = start
}
programs.push({
title: parseTitle(item, channel),
description: parseDescription(item, channel),
episode: parseInt(item.episode_no),
start: start,
stop: stop
})
}
return programs
},
async channels({ lang }) {
const data = await axios
.get(`${API_ENDPOINT}/channel/list?platform=web`)
.then(r => r.data)
.catch(console.error)
return data.channels.map(c => {
const name = lang === 'en' ? c.name_en : c.name_tc
return {
site_id: c.network_code,
name,
lang
}
})
}
}
function parseTitle(item, channel) {
return channel.lang === 'en' ? item.programme_title_en : item.programme_title_tc
}
function parseDescription(item, channel) {
return channel.lang === 'en' ? item.episode_synopsis_en : item.episode_synopsis_tc
}
function parseStart(item) {
return dayjs.tz(item.start_datetime, 'Asia/Hong_Kong')
}
function parseItems(content, date) {
const data = JSON.parse(content)
if (!Array.isArray(data) || !data.length || !Array.isArray(data[0].item)) return []
const dayData = data[0].item.find(i => i.date === date.format('YYYY-MM-DD'))
if (!dayData || !Array.isArray(dayData.epg)) return []
return dayData.epg
}

View File

@@ -1,71 +1,71 @@
// npm run channels:parse -- --config=./sites/mytvsuper.com/mytvsuper.com.config.js --output=./sites/mytvsuper.com/mytvsuper.com.channels.xml --set=lang:zh
// npm run grab -- --site=mytvsuper.com
const { parser, url } = require('./mytvsuper.com.config.js')
const fs = require('fs')
const path = require('path')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
const customParseFormat = require('dayjs/plugin/customParseFormat')
dayjs.extend(customParseFormat)
dayjs.extend(utc)
jest.mock('axios')
const date = dayjs.utc('2022-11-15', 'YYYY-MM-DD').startOf('d')
const channel = {
site_id: 'B',
xmltv_id: 'J2.hk',
lang: 'zh'
}
it('can generate valid url', () => {
expect(url({ channel, date })).toBe(
'https://content-api.mytvsuper.com/v1/epg?network_code=B&from=20221115&to=20221115&platform=web'
)
})
it('can parse response', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.json'))
let results = parser({ content, channel, date })
results = results.map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results[0]).toMatchObject({
start: '2022-11-14T22:00:00.000Z',
stop: '2022-11-14T23:00:00.000Z',
title: '想見你#3[粵/普][PG]',
description:
'韻如因父母離婚都不要自己而跑出家門,遇到子維,兩人互吐心事。雨萱順著照片上的唱片行線索,找到一家同名咖啡店,從文磊處得知照片中人是已經過世的韻如,從而推測那個男生也不是詮勝,但她內心反而更加痛苦。',
episode: 1000003
})
})
it('can parse response in English', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.json'))
const channelEN = { ...channel, lang: 'en' }
let results = parser({ content, channel: channelEN, date })
results = results.map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results[0]).toMatchObject({
start: '2022-11-14T22:00:00.000Z',
stop: '2022-11-14T23:00:00.000Z',
title: 'Someday or One Day#3[Can/Man][PG]',
description: 'Description',
episode: 1000003
})
})
it('can handle empty guide', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/no_content.json'))
const results = parser({ date, channel, content })
expect(results).toMatchObject([])
})
// npm run channels:parse -- --config=./sites/mytvsuper.com/mytvsuper.com.config.js --output=./sites/mytvsuper.com/mytvsuper.com.channels.xml --set=lang:zh
// npm run grab -- --site=mytvsuper.com
const { parser, url } = require('./mytvsuper.com.config.js')
const fs = require('fs')
const path = require('path')
const dayjs = require('dayjs')
const utc = require('dayjs/plugin/utc')
const customParseFormat = require('dayjs/plugin/customParseFormat')
dayjs.extend(customParseFormat)
dayjs.extend(utc)
jest.mock('axios')
const date = dayjs.utc('2022-11-15', 'YYYY-MM-DD').startOf('d')
const channel = {
site_id: 'B',
xmltv_id: 'J2.hk',
lang: 'zh'
}
it('can generate valid url', () => {
expect(url({ channel, date })).toBe(
'https://content-api.mytvsuper.com/v1/epg?network_code=B&from=20221115&to=20221115&platform=web'
)
})
it('can parse response', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.json'))
let results = parser({ content, channel, date })
results = results.map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results[0]).toMatchObject({
start: '2022-11-14T22:00:00.000Z',
stop: '2022-11-14T23:00:00.000Z',
title: '想見你#3[粵/普][PG]',
description:
'韻如因父母離婚都不要自己而跑出家門,遇到子維,兩人互吐心事。雨萱順著照片上的唱片行線索,找到一家同名咖啡店,從文磊處得知照片中人是已經過世的韻如,從而推測那個男生也不是詮勝,但她內心反而更加痛苦。',
episode: 1000003
})
})
it('can parse response in English', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.json'))
const channelEN = { ...channel, lang: 'en' }
let results = parser({ content, channel: channelEN, date })
results = results.map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results[0]).toMatchObject({
start: '2022-11-14T22:00:00.000Z',
stop: '2022-11-14T23:00:00.000Z',
title: 'Someday or One Day#3[Can/Man][PG]',
description: 'Description',
episode: 1000003
})
})
it('can handle empty guide', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/no_content.json'))
const results = parser({ date, channel, content })
expect(results).toMatchObject([])
})