Merge pull request #2087 from iptv-org/fix-telecablesat.fr

Fix telecablesat.fr
This commit is contained in:
Ismaël Moret 2023-06-18 22:54:00 +02:00 committed by GitHub
commit 20ee533c84
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 8 additions and 14 deletions

View file

@ -1,14 +1,6 @@
const cheerio = require('cheerio') const cheerio = require('cheerio')
const axios = require('axios') const axios = require('axios')
const dayjs = require('dayjs') const { DateTime } = require('luxon')
const utc = require('dayjs/plugin/utc')
const timezone = require('dayjs/plugin/timezone')
const customParseFormat = require('dayjs/plugin/customParseFormat')
dayjs.extend(utc)
dayjs.extend(timezone)
dayjs.extend(customParseFormat)
const API_ENDPOINT = 'https://tv-programme.telecablesat.fr/chaine' const API_ENDPOINT = 'https://tv-programme.telecablesat.fr/chaine'
@ -39,13 +31,13 @@ module.exports = {
const $item = cheerio.load(item) const $item = cheerio.load(item)
let start = parseStart($item, date) let start = parseStart($item, date)
if (prev) { if (prev) {
if (start.isBefore(prev.start)) { if (start < prev.start) {
start = start.add(1, 'd') start = start.plus({ days: 1 })
date = date.add(1, 'd') date = date.add(1, 'd')
} }
prev.stop = start prev.stop = start
} }
const stop = start.add(1, 'h') const stop = start.plus({ hours: 1 })
programs.push({ programs.push({
title: parseTitle($item), title: parseTitle($item),
description: parseDescription($item), description: parseDescription($item),
@ -86,7 +78,9 @@ function parseStart($item, date) {
const timeString = $item('.schedule-hour').text() const timeString = $item('.schedule-hour').text()
if (!timeString) return null if (!timeString) return null
return dayjs.tz(`${date.format('YYYY-MM-DD')} ${timeString}`, 'YYYY-MM-DD HH:mm', 'Europe/Paris') return DateTime.fromFormat(`${date.format('YYYY-MM-DD')} ${timeString}`, 'yyyy-MM-dd HH:mm', {
zone: 'Europe/Paris'
}).toUTC()
} }
function parseIcon($item) { function parseIcon($item) {

View file

@ -1,5 +1,5 @@
// npm run channels:parse -- --config=./sites/telecablesat.fr/telecablesat.fr.config.js --output=./sites/telecablesat.fr/telecablesat.fr.channels.xml // npm run channels:parse -- --config=./sites/telecablesat.fr/telecablesat.fr.config.js --output=./sites/telecablesat.fr/telecablesat.fr.channels.xml
// npx epg-grabber --config=sites/telecablesat.fr/telecablesat.fr.config.js --channels=sites/telecablesat.fr/telecablesat.fr.channels.xml --output=guide.xml --days=2 // npx epg-grabber --config=sites/telecablesat.fr/telecablesat.fr.config.js --channels=sites/telecablesat.fr/telecablesat.fr.channels.xml --output=guide.xml
const { parser, url } = require('./telecablesat.fr.config.js') const { parser, url } = require('./telecablesat.fr.config.js')
const axios = require('axios') const axios = require('axios')