|
|
|
|
@ -6,6 +6,7 @@ const {
|
|
|
|
|
open_browser, |
|
|
|
|
parse_args, |
|
|
|
|
read_previous_events, |
|
|
|
|
merge_edges, |
|
|
|
|
} = require('./logic'); |
|
|
|
|
|
|
|
|
|
const { page_ids, output, events: event_file } = parse_args( |
|
|
|
|
@ -22,7 +23,7 @@ const { page_ids, output, events: event_file } = parse_args(
|
|
|
|
|
|
|
|
|
|
for (let page_id of page_ids) { |
|
|
|
|
const past_events = false; |
|
|
|
|
const new_events = get_page_events(browser, page_id, past_events); |
|
|
|
|
const new_events = await get_page_events(browser, page_id, past_events); |
|
|
|
|
|
|
|
|
|
events = merge_edges(new_events, events); |
|
|
|
|
events = events.filter( |
|
|
|
|
@ -32,58 +33,57 @@ const { page_ids, output, events: event_file } = parse_args(
|
|
|
|
|
) === undefined, |
|
|
|
|
); |
|
|
|
|
|
|
|
|
|
events = await Promise.all( |
|
|
|
|
events.map(async (event) => { |
|
|
|
|
const event_page = await browser.newPage(); |
|
|
|
|
const event_data = await load_event(event_page, event.event_id); |
|
|
|
|
event_page.close(); |
|
|
|
|
return { |
|
|
|
|
...event_data, |
|
|
|
|
...event, |
|
|
|
|
}; |
|
|
|
|
}), |
|
|
|
|
); |
|
|
|
|
/* events = await Promise.all( |
|
|
|
|
* events.map(async (event) => { |
|
|
|
|
* const event_page = await browser.newPage(); |
|
|
|
|
* const event_data = await load_event(event_page, event.event_id); |
|
|
|
|
* event_page.close(); |
|
|
|
|
* return { |
|
|
|
|
* ...event_data, |
|
|
|
|
* ...event, |
|
|
|
|
* }; |
|
|
|
|
* }), |
|
|
|
|
* ); */ |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
events = await Promise.all( |
|
|
|
|
events.map(async (event) => { |
|
|
|
|
const images = await save_images(event); |
|
|
|
|
delete event.image; |
|
|
|
|
return { |
|
|
|
|
images, |
|
|
|
|
...event, |
|
|
|
|
}; |
|
|
|
|
}), |
|
|
|
|
); |
|
|
|
|
/* events = await Promise.all( |
|
|
|
|
* events.map(async (event) => { |
|
|
|
|
* const images = await save_images(event); |
|
|
|
|
* delete event.image; |
|
|
|
|
* return { |
|
|
|
|
* images, |
|
|
|
|
* ...event, |
|
|
|
|
* }; |
|
|
|
|
* }), |
|
|
|
|
* ); */ |
|
|
|
|
|
|
|
|
|
if (output === null) { |
|
|
|
|
const all_events = [...events, ...previous_events] |
|
|
|
|
.map((event) => { |
|
|
|
|
const start = pathOr(null, ['date', 'start'], event); |
|
|
|
|
if (start !== null) { |
|
|
|
|
try { |
|
|
|
|
event.date.start = new Date(start); |
|
|
|
|
} catch (e) { |
|
|
|
|
console.error(e); |
|
|
|
|
return event; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
return event; |
|
|
|
|
}) |
|
|
|
|
.sort((a, b) => { |
|
|
|
|
const b_date = b.date.start; |
|
|
|
|
const a_date = a.date.start; |
|
|
|
|
if (a_date > b_date) { |
|
|
|
|
return 1; |
|
|
|
|
const all_events = [...events, ...previous_events] |
|
|
|
|
.map((event) => { |
|
|
|
|
const start = pathOr(null, ['date', 'start'], event); |
|
|
|
|
if (start !== null) { |
|
|
|
|
try { |
|
|
|
|
event.date.start = new Date(start); |
|
|
|
|
} catch (e) { |
|
|
|
|
console.error(e); |
|
|
|
|
return event; |
|
|
|
|
} |
|
|
|
|
if (a_date == b_date) { |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
return -1; |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
return event; |
|
|
|
|
}) |
|
|
|
|
.sort((a, b) => { |
|
|
|
|
const b_date = b.date.start; |
|
|
|
|
const a_date = a.date.start; |
|
|
|
|
if (a_date > b_date) { |
|
|
|
|
return 1; |
|
|
|
|
} |
|
|
|
|
if (a_date == b_date) { |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
return -1; |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
if (output === null) { |
|
|
|
|
console.log(JSON.stringify(all_events)); |
|
|
|
|
process.exit(); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
process.exit(); |
|
|
|
|
})(); |
|
|
|
|
|