Skip to content

Commit

Permalink
Experimental script to render multiple pages to one pdf
Browse files Browse the repository at this point in the history
  • Loading branch information
thvitt committed May 2, 2020
1 parent 81ae822 commit c9f244d
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 5 deletions.
61 changes: 61 additions & 0 deletions render-multi-pages.js
@@ -0,0 +1,61 @@
const puppeteer = require('puppeteer');
const fs = require('fs');
const fsP = fs.promises;


const backend = process.argv[2],
input_base = process.argv[3],
output_base = process.argv[4],
pages = parseInt(process.argv[5]);

if (process.argv.length !== 6) {
console.log('Usage: node rendersvgs.js backend input output pages');
} else {

(async () => {
try {
const browser = await puppeteer.launch({args: ['--no-sandbox'], /* headless: false, slowMo: 100, devtools: true, */ });
try {
const page = await browser.newPage();

page.on('console', msg => {
for (let i = 0; i < msg.args().length; ++i)
console.log(`${i}: ${msg.args()[i]}`);
});

await page.goto(backend, {waitUntil: "domcontentloaded"});
await page.waitForFunction("function() {return typeof(transcriptGeneration.createPromise) === 'function'}")
await page.$eval("#preload", el => el.parentNode.removeChild(el));

for (let i = 1; i <= pages; i++) {
console.log("Rendering page ", i)
let input = input_base + i + ".json",
output = output_base + i + ".svg";

const transcript = await fsP.readFile(input, {encoding: "utf-8"});

const result = await page.evaluate((t) => {
return Promise.race([
transcriptGeneration.createPromise(t),
new Promise((_, reject) => setTimeout(reject, 30000, 'Rendering took more than 30 seconds'))
]);
}, transcript);

await fsP.writeFile(output, result.svg, {encoding: "utf-8"});
}

console.log("Saving PDF ...")
await page.pdf({
path: output_base + ".pdf",
format: 'A4',
margin: ['2cm', '2cm', '2cm', '2cm']
});
} finally {
browser.close();
}
} catch (e) {
console.error(e);
}

})();
}
6 changes: 1 addition & 5 deletions svg_rendering/page/js-gen/transcript-generation.js
Expand Up @@ -43,11 +43,7 @@ var transcriptGeneration = (function () {
// renderContainer.style.height = "0px";
// renderContainer.style.width = "0px";

renderContainer.style.overflow = "auto";
renderContainer.style.height = "100%";
renderContainer.style.position = "fixed";
renderContainer.style.top = "0px";
renderContainer.style.left = "0px";
renderContainer.className = "rendercontainer";

return renderContainer;
};
Expand Down
16 changes: 16 additions & 0 deletions svg_rendering/page/transcript-generation.html
Expand Up @@ -36,6 +36,22 @@
/* background-color: lightgray; */
}

@media screen {
.rendercontainer {
overflow: auto;
height: 100%;
position: fixed;
top: 0px;
left: 0px;
}
}

@media print {
.rendercontainer {
break-after: page;
}
}

/*
#container {
border: 1px solid black;
Expand Down

0 comments on commit c9f244d

Please sign in to comment.