Replace LF endings with CRLF

This commit is contained in:
freearhey
2025-07-31 22:29:01 +03:00
parent 17e3b4ddda
commit 29aa427923
379 changed files with 29332 additions and 29332 deletions

View File

@@ -1,82 +1,82 @@
const cheerio = require('cheerio')
const dayjs = require('dayjs')
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)
module.exports = {
site: 'virginmediatelevision.ie',
days: 2,
url({ date }) {
return `https://www.virginmediatelevision.ie/includes/ajax/tv_guide.php?date=${date.format(
'YYYY-MM-DD'
)}`
},
request: {
cache: {
ttl: 60 * 60 * 1000 // 1h
}
},
parser({ content, channel, date }) {
const programs = []
const items = parseItems(content, channel)
items.forEach(item => {
const $item = cheerio.load(item)
let start = parseStart($item, date)
let duration = parseDuration($item)
let stop = start.add(duration, 'm')
programs.push({
title: parseTitle($item),
description: parseDescription($item),
sub_title: parseSubTitle($item),
image: parseImage($item),
start,
stop
})
})
return programs
}
}
function parseTitle($item) {
return $item('.info > h2').text().trim()
}
function parseDescription($item) {
return $item('.info').data('description')
}
function parseSubTitle($item) {
return $item('.info').data('subtitle')
}
function parseImage($item) {
return $item('.info').data('image')
}
function parseStart($item, date) {
const [time] = $item('.info')
.data('time')
.match(/^\d{1,2}\.\d{2}(am|pm)/) || [null]
if (!time) return null
return dayjs.tz(`${date.format('YYYY-MM-DD')} ${time}`, 'YYYY-MM-DD h.mma', 'Europe/London')
}
function parseDuration($item) {
const duration = $item('.info > .time').data('minutes')
return duration ? parseInt(duration) : 30
}
function parseItems(content, channel) {
const $ = cheerio.load(content)
return $(`.programs_parent > .programs[data-channel='${channel.site_id}'] > .program`).toArray()
}
const cheerio = require('cheerio')
const dayjs = require('dayjs')
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)
module.exports = {
site: 'virginmediatelevision.ie',
days: 2,
url({ date }) {
return `https://www.virginmediatelevision.ie/includes/ajax/tv_guide.php?date=${date.format(
'YYYY-MM-DD'
)}`
},
request: {
cache: {
ttl: 60 * 60 * 1000 // 1h
}
},
parser({ content, channel, date }) {
const programs = []
const items = parseItems(content, channel)
items.forEach(item => {
const $item = cheerio.load(item)
let start = parseStart($item, date)
let duration = parseDuration($item)
let stop = start.add(duration, 'm')
programs.push({
title: parseTitle($item),
description: parseDescription($item),
sub_title: parseSubTitle($item),
image: parseImage($item),
start,
stop
})
})
return programs
}
}
function parseTitle($item) {
return $item('.info > h2').text().trim()
}
function parseDescription($item) {
return $item('.info').data('description')
}
function parseSubTitle($item) {
return $item('.info').data('subtitle')
}
function parseImage($item) {
return $item('.info').data('image')
}
function parseStart($item, date) {
const [time] = $item('.info')
.data('time')
.match(/^\d{1,2}\.\d{2}(am|pm)/) || [null]
if (!time) return null
return dayjs.tz(`${date.format('YYYY-MM-DD')} ${time}`, 'YYYY-MM-DD h.mma', 'Europe/London')
}
function parseDuration($item) {
const duration = $item('.info > .time').data('minutes')
return duration ? parseInt(duration) : 30
}
function parseItems(content, channel) {
const $ = cheerio.load(content)
return $(`.programs_parent > .programs[data-channel='${channel.site_id}'] > .program`).toArray()
}

View File

@@ -1,51 +1,51 @@
const { parser, url } = require('./virginmediatelevision.ie.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)
const date = dayjs.utc('2023-01-31', 'YYYY-MM-DD').startOf('d')
const channel = {
site_id: 'one',
xmltv_id: 'VirginMediaOne.ie'
}
it('can generate valid url', () => {
expect(url({ date })).toBe(
'https://www.virginmediatelevision.ie/includes/ajax/tv_guide.php?date=2023-01-31'
)
})
it('can parse response', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.html'), 'utf8')
let results = parser({ content, channel, date })
results = results.map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results.length).toBe(23)
expect(results[0]).toMatchObject({
start: '2023-01-31T00:00:00.000Z',
stop: '2023-01-31T01:00:00.000Z',
title: 'Chasing Shadows',
sub_title: '',
description:
'A detective sergeant and expert in the field of serial killers working for the Missing Persons Bureau tries to protect the general public from evil.',
image: 'https://bcboltvirgin.akamaized.net/player/shows/1498_517x291_1528141264.jpg'
})
})
it('can handle empty guide', () => {
const results = parser({
date,
channel,
content: '<!DOCTYPE html><html><head></head><body></body></html>'
})
expect(results).toMatchObject([])
})
const { parser, url } = require('./virginmediatelevision.ie.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)
const date = dayjs.utc('2023-01-31', 'YYYY-MM-DD').startOf('d')
const channel = {
site_id: 'one',
xmltv_id: 'VirginMediaOne.ie'
}
it('can generate valid url', () => {
expect(url({ date })).toBe(
'https://www.virginmediatelevision.ie/includes/ajax/tv_guide.php?date=2023-01-31'
)
})
it('can parse response', () => {
const content = fs.readFileSync(path.resolve(__dirname, '__data__/content.html'), 'utf8')
let results = parser({ content, channel, date })
results = results.map(p => {
p.start = p.start.toJSON()
p.stop = p.stop.toJSON()
return p
})
expect(results.length).toBe(23)
expect(results[0]).toMatchObject({
start: '2023-01-31T00:00:00.000Z',
stop: '2023-01-31T01:00:00.000Z',
title: 'Chasing Shadows',
sub_title: '',
description:
'A detective sergeant and expert in the field of serial killers working for the Missing Persons Bureau tries to protect the general public from evil.',
image: 'https://bcboltvirgin.akamaized.net/player/shows/1498_517x291_1528141264.jpg'
})
})
it('can handle empty guide', () => {
const results = parser({
date,
channel,
content: '<!DOCTYPE html><html><head></head><body></body></html>'
})
expect(results).toMatchObject([])
})