Skip to content
This repository has been archived by the owner on Mar 8, 2024. It is now read-only.

Commit

Permalink
Merge pull request #43 from proshunsuke/v8
Browse files Browse the repository at this point in the history
V8
  • Loading branch information
proshunsuke authored Apr 17, 2021
2 parents 860a4e7 + 5624bea commit c124ebc
Show file tree
Hide file tree
Showing 2 changed files with 42 additions and 32 deletions.
3 changes: 3 additions & 0 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,9 @@ push: build
run:
yarn clasp run execute

run/local:
node -e 'require("./dist/index.js");global.setSchedule();'

open:
yarn clasp open

Expand Down
71 changes: 39 additions & 32 deletions gcpFunctions/getSakuraSchedule.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,42 +13,49 @@ exports.getSakuraSchedule = async (req, res) => {
page = await getBrowserPage();
}

await page.goto('https://sakurazaka46.com/s/s46/media/list?dy=' + req.query['date']);

const scheduleEvents = await page.evaluate("scheduleEvents");

const scheduleDateList = Array.from(new Set(scheduleEvents.map((scheduleEvent) => scheduleEvent.start.replace(/-/g, ''))));

const result = [];

for await (const scheduleDate of scheduleDateList) {
await page.goto('https://sakurazaka46.com/s/s46/media/list?dy=' + scheduleDate);
const scheduleContexts = await page.$$('.com-arclist-part li.box');
for (const scheduleContext of scheduleContexts) {
const type = await (await scheduleContext.$('.type')).evaluate((el) => el.textContent) || 'その他';
const times = await (await scheduleContext.$('.times')).evaluate((el) => el.textContent);
const modalCount = (await (await scheduleContext.$('.js-schedule-detail-modal')).evaluate((el) => el.href)).replace(/^.*#/g, '');
const date = await (await page.$(`.${modalCount} .date.wf-a`)).evaluate((el) => el.textContent);
const title = await (await page.$(`.${modalCount} .title`)).evaluate((el) => el.textContent);
const members = await Promise.all(
(await page.$$(`.${modalCount} .members.fx > li`)).map(async (liElement) => await liElement.evaluate((el) => el.textContent))
);
const scheduleObject = {title: title, date: date, type: type};
if (times) {
const startTime = formattedDate(date, times.replace(/.*/, ''));
const endTimeHourMin = times.replace(/.*/, '');
const endTime = endTimeHourMin ? formattedDate(date, endTimeHourMin) : startTime;
scheduleObject.startTime = startTime;
scheduleObject.endTime = endTime;
}
if (members.length !== 0) scheduleObject.description = `メンバー: ${members.join(', ')}`;
result.push(scheduleObject);
}
}
await page.setUserAgent('Mozilla/5.0 (iPhone; CPU iPhone OS 13_2_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Mobile/15E148 Safari/604.1');

const date = req.query['date'];
const url = 'https://sakurazaka46.com/s/s46/media/list?ima=5250&dy=' + date.substring(0, date.length - 2);
await page.goto(url);

const modalScheduleDetails = await page.$$('.module-modal.js-schedule-detail');
let result = await modalScheduleDetails.reduce(async (list, modalScheduleDetail) => {
const l = (await list);
const date = await (await modalScheduleDetail.$('.date.wf-a')).evaluate((el) => el.textContent);
const title = await (await modalScheduleDetail.$('.title')).evaluate((el) => el.textContent);
const members = await Promise.all(
(await modalScheduleDetail.$$('.members.fx > li')).map(async (li) => await li.evaluate((el) => el.textContent))
);
const scheduleObject = {title, date};
if (members.length !== 0) scheduleObject.description = `メンバー: ${members.join(', ')}`;
l.push(scheduleObject);
return l;
}, []);

const scheduleDetailModals = await page.$$('.js-schedule-detail-modal');
result = await scheduleDetailModals.reduce(async (list, scheduleDetailModal, index) => {
const l = await list;
const type = await (await scheduleDetailModal.$('.type')).evaluate((el) => el.textContent) || 'その他';
const times = await (await scheduleDetailModal.$('.times')).evaluate((el) => el.textContent);

let scheduleObject = {type};
if (times) scheduleObject = {...scheduleObject, ...startEndTimeObject(l[index].date, times)};

l[index] = {...l[index], ...scheduleObject};
return l;
}, result);

res.send(result);
};

function startEndTimeObject(date, times) {
const startTime = formattedDate(date, times.replace(/.*/, ''));
const endTimeHourMin = times.replace(/.*/, '');
const endTime = endTimeHourMin ? formattedDate(date, endTimeHourMin) : startTime;
return {startTime, endTime};
}

function formattedDate(date, hourMin) {
if ((new Date(`${date} ${hourMin}`)).toString() !== 'Invalid Date') return `${date} ${hourMin}`;
const hour = parseInt(hourMin.replace(/:.*/, ''));
Expand Down

0 comments on commit c124ebc

Please sign in to comment.