Giter VIP home page Giter VIP logo

Comments (11)

chinapandaman avatar chinapandaman commented on September 21, 2024 1

Hey, I just made a new bump. Turns out to be easier than I thought. Performance might be a bit concerning but I will get to that later. Give v1.4.24 a try and let me know if there are more issues.

from pypdfform.

chinapandaman avatar chinapandaman commented on September 21, 2024

Hey, thanks for posting.

The issue you ran into was somewhat discussed in another thread, specifically I did a rather detailed explanation here.

In short, Adobe Acrobat seems to require way more complex metadata than browsers like Chrome for a text field widget to be rendered properly. This level of complexity is something that I'm unable to implement unfortunately. This is the largest reason why PdfWrapper exists in the first place.

from pypdfform.

plapointe6 avatar plapointe6 commented on September 21, 2024

Thanks. The only downside of PdfWrapper is that it does not implements automatic font size depending of the content as FormWrapper do when the fields are correctly configured in the pdf. This cause me issues as the text overflow instead of reducing its size. especially for multi-line fields.

from pypdfform.

chinapandaman avatar chinapandaman commented on September 21, 2024

It’s normal for regular text field to overflow but that shouldn’t be the case for multi-line paragraph field. Could you post me an example?

Edit: unless for paragraph field it overflows vertically?

from pypdfform.

plapointe6 avatar plapointe6 commented on September 21, 2024

Only for multiline fields I think.

Here is an exemple:

from PyPDFForm import PdfWrapper

filled = PdfWrapper("report.pdf",).fill(
    {
        "301 What Happened": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris congue, lorem sit amet venenatis lacinia, quam tortor pharetra ante, id facilisis neque velit ac tellus. Nam tincidunt felis quis eros malesuada, ac congue elit consequat. Ut eget porttitor augue. Integer ullamcorper lectus et est scelerisque, ac posuere mi tempor. Nunc vulputate vehicula bibendum. Aliquam erat volutpat. Morbi tortor."
    }
)

with open("filled.pdf", "wb+") as output:
    output.write(filled.read())

Input: report.pdf
Output: filled.pdf

Result:
image

from pypdfform.

chinapandaman avatar chinapandaman commented on September 21, 2024

So in other words paragraph field overflows vertically. Ok this is actually expected behavior. I’ll implement an auto adjusting mechanism no later than the end of this week and get back to you.

from pypdfform.

plapointe6 avatar plapointe6 commented on September 21, 2024

Great ! Thanks a lot.

from pypdfform.

plapointe6 avatar plapointe6 commented on September 21, 2024

It works. Thanks !

I found that if I set the global_font_size, it overrides the new adaptative font behavior though.
Is the default font size used by PdfWrapper come from the PDF configuration or it is embeded in the lib ?

from pypdfform.

chinapandaman avatar chinapandaman commented on September 21, 2024

When you set a font size, I assume you know what you are doing and know the risk of larger font size would potentially cause texts overflowing. So yes setting font size does overwrite the auto adjust behavior.

The default font size for paragraph field is set to 12 and embedded into the lib. I don't know how to extract that info out of a PDF. If you happen to know I'm all ears.

from pypdfform.

plapointe6 avatar plapointe6 commented on September 21, 2024

Make sense.

No, I don't know a way to extract that info out of a PDF.

Maybe in the future, I will make a pull request to add an optional parameter "default_font_size" to override the embedded 12 while maintaining the automatic font adjustment.

But my issue is well resolved. Thanks for your help.

from pypdfform.

chinapandaman avatar chinapandaman commented on September 21, 2024

Hey man, I know this might be a bit late into the party but just want to throw this here if you still need it: https://chinapandaman.github.io/PyPDFForm/simple_fill/#adobe-mode-beta

It's still in beta and there are some hiccups with this messing up checkbox and radio button styles. But I tested your template and it should be good for at least text fields.

from pypdfform.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.