feat: add blur studio (#4566)

This commit is contained in:
MisteryMonster
2020-04-28 15:50:30 +08:00
committed by GitHub
parent 9eb5dfb595
commit 03c6f99d22
4 changed files with 96 additions and 0 deletions

View File

@@ -4,6 +4,12 @@ pageClass: routes
# 设计
## Blur Studio
### Works
<Route author="MisteryMonster" example="/blur-studio" path="/blur-studio" />
## Blow Studio
### 主页

View File

@@ -4,6 +4,12 @@ pageClass: routes
# Design
## Blur Studio
### Works
<RouteEn author="MisteryMonster" example="/blur-studio" path="/blur-studio" />
## Blow Studio
### Home

View File

@@ -2574,6 +2574,9 @@ router.get('/zhuixinfan/list', require('./routes/zhuixinfan/list'));
// scoresaber
router.get('/scoresaber/user/:id', require('./routes/scoresaber/user'));
// blur-studio
router.get('/blur-studio', require('./routes/blur-studio/index'));
// Sun-Creature
router.get('/sun-creature', require('./routes/sun-creature/index'));

81
lib/routes/blur-studio/index.js Executable file
View File

@@ -0,0 +1,81 @@
const got = require('@/utils/got');
const cheerio = require('cheerio');
module.exports = async (ctx) => {
const response = await got({
method: 'get',
url: `http://blur.com`,
});
const data = response.data;
const $ = cheerio.load(data); // 使用 cheerio 加载返回的 HTML
const list = $('.page-title a').get();
const articledata = await Promise.all(
list.map(async (item) => {
const link = $(item).attr('href');
const cache = await ctx.cache.get(link);
if (cache) {
return Promise.resolve(JSON.parse(cache));
}
const response2 = await got({
method: 'get',
url: link,
});
const articleHtml = response2.data;
const $2 = cheerio.load(articleHtml);
const imglist = $2('.gridded img').get();
const videolist = $2('.gridded iframe').get();
const img = imglist.map((item) => ({
img: $2(item).attr('src'),
}));
const video = videolist.map((item) => ({
video: $2(item).attr('src'),
}));
const single = {
mainvideo: $2('div.project-title').attr('data-video'),
describe: $2('p').text(),
title: $2('h1.page-title').text(),
client: $2('div.client').text(),
images: img,
video: video,
link: link,
};
ctx.cache.set(link, JSON.stringify(single));
return Promise.resolve(single);
})
);
ctx.state.data = {
title: 'Blur Studio',
link: 'http://blur.com',
description: $('description').text(),
item: list.map((item, index) => {
const Num = /[0-9]+/;
let content = '';
const videostyle = `width="640" height="360"`;
const imgstyle = `style="max-width: 650px; height: auto; object-fit: contain; flex: 0 0 auto;"`;
content += `Client:${articledata[index].client}<br>${articledata[index].describe}`;
if (Num.test(articledata[index].mainvideo)) {
content += `<iframe ${videostyle} src='https://player.vimeo.com/video/${articledata[index].mainvideo}' frameborder='0' webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe><br>`;
} else {
content += `<iframe ${videostyle} src='https://youtube.com/embed/${articledata[index].mainvideo}' frameborder='0' webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe><br>`;
}
if (articledata[index].images) {
for (let p = 0; p < articledata[index].images.length; p++) {
content += `<img ${imgstyle} src="${articledata[index].images[p].img}"><br>`;
}
}
if (articledata[index].video) {
for (let v = 0; v < articledata[index].video.length; v++) {
content += `<iframe ${videostyle} src='${articledata[index].video[v].video}' frameborder='0' webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe><br>`;
}
}
return {
title: `${articledata[index].title}`,
description: `${content}`,
link: `${articledata[index].link}`,
};
}),
};
};