Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Failing to render the mobile view on print #218

Open
zarembas opened this issue Jan 14, 2024 · 5 comments
Open

Failing to render the mobile view on print #218

zarembas opened this issue Jan 14, 2024 · 5 comments

Comments

@zarembas
Copy link

I am trying to switch from pdfkit to grover and for whatever reason pdfkit was printing the pages in mobile view by default without any configs. This worked in our favour as the mobile view is more print friendly.

But now I'm struggling to replicate this behaviour.

I tried to changed the viewport to a value that would trigger the mobile view, but this doesn't seem to work:

config.options = {
  format: 'A4',
  margin: {
    top: '1.5cm',
    bottom: '1.5cm',
    left: '1.5cm',
    right: '1.5cm',
  },
  viewport: {
    width: 640,
    height: 900,
  },
  print_background: true,
  scale: 0.8,
  launch_args: ['--disable-dev-shm-usage', '--no-sandbox', '--disable-setuid-sandbox'],
}

Is it possible to achieve this without creating specific views? Am I using the viewport setting incorrectly?

@abrom
Copy link
Contributor

abrom commented Jan 15, 2024

it's not entirely clear what you're asking here, and it's also not entirely clear what you've tried in isolation to other attempts.
The viewport option will tell Puppeteer to set the page viewport size (and potentially the device scale factor) https://pptr.dev/api/puppeteer.page.setviewport

Are you saying that you have CSS that uses media queries to reflow your page at different break points?

What happens if you view the page you're trying to convert in Chrome with the width/height set to 640/900. Does that look right?

Then if you go to the print preview ? That's what Puppeteer will essentially return.. Does that look right?

@zarembas
Copy link
Author

Sorry for not making it clearer, Are you saying that you have CSS that uses media queries to reflow your page at different break points? this is correct. We are using an external library for that, it triggers the mobile layout at 640 width, but it does seem that even when in mobile view, Chrome prints the full layout of the page. So this might be the way Chrome handles printing and not much Grover can do about it.

@abrom
Copy link
Contributor

abrom commented Jan 18, 2024

It sounds like this CSS library you're using only applies to the screen media type and not print (ie what Grover/puppeteer uses by default). That's what I was trying to ask RE the print preview but your answer was a bit vague.

If that is the case, then adding emulate_media: 'screen' to the Grover options/config would likely fix it.

@zarembas
Copy link
Author

I have tried with emulate_media: 'screen', but the viewport's width doesn't make a difference when printing.

@abrom
Copy link
Contributor

abrom commented Mar 9, 2024

Did you try set the width and height but NOT set the page format? I see you're setting it to A4 which will likely overload the width and height options.

This works fine for me:

Grover.new('foo', width: 100, height: 100).to_pdf

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants