const axios = require('@/utils/axios');
const cheerio = require('cheerio');
const Parser = require('rss-parser');
const parser = new Parser();
module.exports = async (ctx) => {
const feed = await parser.parseURL('https://www.theverge.com/rss/index.xml');
const items = await Promise.all(
feed.items.slice(0, 10).map(async (item) => {
const response = await axios({
method: 'get',
url: item.link,
});
const $ = cheerio.load(response.data);
const content = $('div.c-entry-content');
// 处理封面图片
const cover = $('meta[property="og:image"]');
if (cover.length > 0) {
$(`
`).insertBefore(content[0].childNodes[0]);
}
// 处理封面视频
$('div.l-col__main > div.c-video-embed, div.c-entry-hero > div.c-video-embed').each((i, e) => {
const src = `https://volume.vox-cdn.com/embed/${e.attribs['data-volume-uuid']}?autoplay=false`;
$(``).insertBefore(content[0].childNodes[0]);
});
// 处理封面视频
$('div.l-col__main > div.c-video-embed--media iframe').each((i, e) => {
$(e).insertBefore(content[0].childNodes[0]);
});
// 处理文章图片
content.find('figure.e-image').each((i, e) => {
let src, caption;
// 处理 jpeg, png
if ($(e).find('picture > source').length > 0) {
src = $(e)
.find('picture > img')[0]
.attribs.srcset.match(/(?<=320w,).*?(?=520w)/g)[0]
.trim();
} else if ($(e).find('img.c-dynamic-image').length > 0) {
// 处理 gif
src = $(e).find('span.e-image__image')[0].attribs['data-original'];
}
// 处理 caption
if ($(e).find('span.e-image__meta').length > 0) {
caption = $(e)
.find('span.e-image__meta')
.text();
}
const figure = `
${caption ? `
${caption}` : ''}`;
$(figure).insertBefore(e);
$(e).remove();
});
// 移除无用 DOM
content.find('aside').each((i, e) => {
$(e).remove();
});
const single = {
title: item.title,
description: content.html(),
author: item.author,
pubDate: item.pubDate,
link: item.link,
};
return Promise.resolve(single);
})
);
ctx.state.data = {
title: feed.title,
link: feed.link,
description: feed.description,
item: items,
};
};