mirror of
https://github.com/astefanutti/decktape.git
synced 2024-11-09 18:09:14 +03:00
056002fcdc
BREAKING CHANGE: Please run node 12.20 or higher BREAKING CHANGE: This package is now a pure esm, please [read this](https://gist.github.com/sindresorhus/a39789f98801d908bbc7ff3ecc99d99c)
77 lines
1.9 KiB
JavaScript
77 lines
1.9 KiB
JavaScript
export const create = page => new Remark(page);
|
|
|
|
class Remark {
|
|
|
|
constructor(page) {
|
|
this.page = page;
|
|
}
|
|
|
|
getName() {
|
|
return 'Remark JS';
|
|
}
|
|
|
|
isActive() {
|
|
return this.page.evaluate(_ =>
|
|
typeof remark === 'object' && typeof slideshow === 'object');
|
|
}
|
|
|
|
async configure() {
|
|
await this.page.evaluate(_ => {
|
|
for (let j = 0; j < document.styleSheets.length; j++) {
|
|
const sheet = document.styleSheets[j];
|
|
if (!sheet.rules) continue;
|
|
for (let i = sheet.rules.length - 1; i >= 0; i--) {
|
|
if (sheet.rules[i] instanceof window.CSSPageRule) {
|
|
sheet.deleteRule(i);
|
|
}
|
|
}
|
|
}
|
|
// Add a style to adjust for PDF export
|
|
const style = document.createElement('style');
|
|
document.head.appendChild(style);
|
|
style.sheet.insertRule(`
|
|
@media screen {
|
|
.remark-slide {
|
|
/* Default 'table' diplay does not work with Chrome PDF export */
|
|
display: inline-table;
|
|
}
|
|
.remark-slide-content {
|
|
display: table-cell;
|
|
}
|
|
.remark-slide-scaler {
|
|
/* Remove slides box shadows */
|
|
box-shadow: none;
|
|
}
|
|
}`);
|
|
});
|
|
}
|
|
|
|
size() {
|
|
return this.page.evaluate(_ => {
|
|
const [referenceWidth, referenceHeight] = [908, 681];
|
|
const [width, height] = slideshow.getRatio().split(':').map(d => parseInt(d, 10));
|
|
return {
|
|
width : Math.floor(referenceHeight * width / height),
|
|
height : referenceHeight,
|
|
};
|
|
});
|
|
}
|
|
|
|
slideCount() {
|
|
return this.page.evaluate(_ => slideshow.getSlideCount());
|
|
}
|
|
|
|
hasNextSlide() {
|
|
return this.page.evaluate(_ =>
|
|
slideshow.getCurrentSlideIndex() + 1 < slideshow.getSlideCount());
|
|
}
|
|
|
|
nextSlide() {
|
|
return this.page.evaluate(_ => slideshow.gotoNextSlide());
|
|
}
|
|
|
|
currentSlideIndex() {
|
|
return this.page.evaluate(_ => slideshow.getCurrentSlideIndex() + 1);
|
|
}
|
|
}
|