You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

110 lines
2.6 KiB

2 years ago
import puppeteer from 'puppeteer';
import fs from 'fs';
import moment from 'moment';
import PDFMerger from 'pdf-merger-js';
2 years ago
let [
url,
title = '',
subtitle = '',
date = moment().format('YYYY-MM-DD')
] = process.argv.slice(2);
2 years ago
const path = './pdf';
if (!fs.existsSync(path)) fs.mkdirSync(path);
let browser;
try{
browser = await puppeteer.launch({
headless: true,
args: [
"--disable-gpu",
"--disable-dev-shm-usage",
"--disable-setuid-sandbox",
"--no-sandbox",
]
});
const page = await browser.newPage();
page.setDefaultNavigationTimeout(0);
await page.goto(url);
await Promise.any([
page.mainFrame().waitForNavigation({waitUntil: 'networkidle0'}),
new Promise(resolve => setTimeout(resolve,1000))
]);
if (!title) title = await (await page.waitForSelector('h1')).evaluate(el => el.textContent);
if (!subtitle) subtitle = await (await page.waitForSelector('h2')).evaluate(el => el.textContent);
console.log(title,subtitle)
const pages = await page.pdf({
//path: `${path}/${date}_${title}_pages.pdf`,
2 years ago
format: 'A4',
margin: {
top: '20mm',
bottom: '20mm',
left: '12mm',
right: '12mm'
},
displayHeaderFooter: true,
headerTemplate: `
<div style="
text-align: center;
color: #000;
font-family: sans-serif;
font-size: 10px;
width: 100%;
padding: 2mm;
border-bottom: 1px #222 solid;
">${[title, subtitle].map(el=>el.trim()).filter(el=>!!el).join(' - ')}</div>
2 years ago
`,
footerTemplate: `
<div style="
text-align: center;
color: #000;
font-family: sans-serif;
font-size: 10px;
width: 100%;
padding: 2mm;
">Page <span class="pageNumber"></span></div>
`,
printBackground: true
});
let coverHTML = fs.readFileSync('./cover.html', {encoding: 'utf-8', flag: 'r'});
Object.entries({
title, subtitle, date
}).forEach(([key, value]) => {
coverHTML = coverHTML.replaceAll(`{{${key}}}`, value);
});
const page2 = await browser.newPage();
await page2.setContent(coverHTML);
const cover = await page2.pdf({
//path: `${path}/${date}_${title}_cover.pdf`,
format: 'A4',
margin: {
top: '20mm',
bottom: '20mm',
left: '12mm',
right: '12mm'
}
});
2 years ago
await browser.close();
const merger = new PDFMerger();
merger.add(cover);
merger.add(pages);
await merger.save(`${path}/${date}_${title.trim().replaceAll(' ', '_')}.pdf`)
2 years ago
} catch (e) {
if (browser) await browser.close();
throw e;
}
console.log('finished');