getFileData doesn't contain proper annotations

Product: @pdftron/webviewer

Product Version: 7.3.3

Please give a brief summary of your issue:

  • Generating base 64 from annotations doesn’t add bold, underline, italic text on a “Free Text” annotation.

ISSUE IN DETAIL:

I have the following Free Text Annotation on my document:

When I render the document, I can successfully import annotations from the xfdfString.
When I try to generate a base64 from this document, I end up with the following on my b64:

image

As you can see, it doesn’t match.

My code, upon generating the base 64, is as follows:

    const annotations = await annotManager.getAnnotationsList();
    const xfdfString = await annotManager.exportAnnotations({ annotList: annotations });
    const docbuf = await instance.docViewer.getDocument().getFileData({ xfdfString });

etc...

xfdString` is the following:

<?xml version="1.0" encoding="UTF-8" ?><xfdf xmlns="http://ns.adobe.com/xfdf/" xml:space="preserve"><annots><freetext page="0" rect="149.97,705.44,409.1,778.22" flags="print" name="30c9188e-4520-15f9-03fe-3df371c959ef" title="Guest" subject="Free Text" date="D:20211002235312+01'00'" width="0" creationdate="D:20211002235239+01'00'" TextColor="#000000" FontSize="10"><trn-custom-data bytes="{&quot;trn-wrapped-text-lines&quot;:&quot;[\&quot;hello there :) \&quot;,\&quot;this is bold \&quot;,\&quot;this is italic \&quot;,\&quot;and this is underline \&quot;]&quot;}"/><contents>hello there :)
this is bold
this is italic
and this is underline</contents><contents-richtext><body><p><span style="color:#000000">hello there :)</span><span>
</span><span style="font-weight:bold;color:#000000">this is bold</span><span>
</span><span style="color:#000000">this is </span><span style="font-style:italic;color:#000000">italic</span><span>
</span><span style="color:#000000">and this is </span><span style="color:#000000;text-decoration:word">underline</span><span/></p></body></contents-richtext><defaultappearance>0 0 0 rg /Helvetica 10 Tf</defaultappearance><defaultstyle>font: Helvetica 10pt; text-align: left; color: #000000</defaultstyle><apref-replace/></freetext><stamp page="0" rect="259.59000000000003,509.93434782608676,387.12,581.5899999999999" flags="print" name="791d3c12-e52c-120e-bae6-02693a4affc6" title="Guest" subject="Stamp" date="D:20211002235435+01'00'" creationdate="D:20211002235428+01'00'" icon="Draft"><trn-custom-data bytes="{&quot;trn-annot-maintain-aspect-ratio&quot;:true}"/><imagedata></imagedata></stamp><ink page="0" rect="272.4047619047618,342,388.59523809523813,382" color="#000000" flags="print" name="09284ae6-4a07-9633-9931-b26c2217b05b" title="e363ac3d-feef-48e5-a442-0cac492a8d7c" subject="Signature" date="D:20211003001044+01'00'" width="0.8" creationdate="D:20211003001044+01'00'"><trn-custom-data bytes="{&quot;trn-annot-maintain-aspect-ratio&quot;:true,&quot;trn-annot-no-resize&quot;:true,&quot;trn-annot-no-move&quot;:true}"/><inklist><gesture>273.88624338624334,363.058201058201;273.88624338624334,362.5291005291005;273.88624338624334,362.5291005291005;275.4735449735449,362.5291005291005;278.11904761904754,362.5291005291005;283.41005291005285,362.5291005291005;286.0555555555555,362.5291005291005;293.4629629629629,361.47089947089944;302.98677248677245,358.2962962962963;321.5052910052909,351.41798941798936;325.2089947089947,350.35978835978835;344.2566137566138,344.01058201058197;355.36772486772486,342.9523809523809;363.83333333333337,342.42328042328035;372.82804232804233,344.01058201058197;375.473544973545,345.59788359788354;378.11904761904765,348.2433862433862;381.29365079365084,352.4761904761904;381.82275132275134,353.5343915343915;382.35185185185185,354.06349206349205;382.8809523809524,355.1216931216931;383.4100529100529,355.6507936507936</gesture><gesture>388.1719576719577,381.5767195767196;387.6428571428572,381.5767195767196;385.5264550264551,380.51851851851853;380.2354497354498,377.34391534391534;373.88624338624345,374.6984126984127;362.77513227513225,369.93650793650795;346.9021164021164,365.17460317460313;343.1984126984127,363.58730158730157;333.14550264550263,361.47089947089944;319.91798941798936,358.8253968253968;318.85978835978835,358.8253968253968;311.4523809523809,356.7089947089947;306.16137566137564,355.6507936507936;301.9285714285714,354.06349206349205;298.7539682539682,353.5343915343915;294.52116402116394,353.005291005291;292.9338624338624,352.4761904761904;287.11375661375655,351.41798941798936;286.0555555555555,351.41798941798936;280.7645502645502,349.8306878306878;277.06084656084647,348.2433862433862;274.41534391534384,346.6560846560846;273.88624338624334,346.6560846560846;273.3571428571428,346.1269841269841;272.8280423280422,346.1269841269841</gesture></inklist></ink></annots></xfdf>

Can you please provide some insight, as this is currently blocking us ?

Thanks,
Tiago

Just to emphasise that I’m only addressing the bold / italic / underline - not the size of the text - the screenshots are a bit different, but just because of the zoom.

Hello Tiago,

Thank you for your report.

How are you bolding and underlining the text inside the free text annotation?

Best Regards,
Jason Hu
Web Development Support Engineer
PDFTron Systems, Inc.
www.pdftron.com

Hi Jason, thanks for the reply - I think i know where this is going, but yes, I’m adding them via CMD + b , CMD + i and CMD + u

The text does get changed when interacting within the Free Text Annotation - so I’m assuming it should be a valid way of doing it?

Hello Tiago,

XFDF string should have a tag that saves the information you were looking for.
The XFDF string you sent me has such tags, that means, you are probably exporting the annotation in the right way, but not importing correctly.

Here is the code snippet that I used to test, I was able to get back the formatted free text annotations:

  const { documentViewer, annotationManager,SaveOptions  } = instance.Core;
  let blob  = null;
  instance.UI.setHeaderItems(header => {
    header.push({
      type: 'actionButton',
      img: '',
      onClick: async () => {

        const doc = documentViewer.getDocument();
        const xfdfString = await annotationManager.exportAnnotations();
        const saveOptions = SaveOptions;
        const options = {
          xfdfString,
          flags: saveOptions.LINEARIZED,
          downloadType: 'pdf'
        };
        const data = await doc.getFileData(options);
        const arr = new Uint8Array(data);
        blob = new Blob([arr], { type: 'application/pdf' });

        // add code for handling Blob here
        console.log('lastFileBlob',blob)
      }
    });
  });
  instance.UI.setHeaderItems(header => {
    header.push({
        type: 'actionButton',
        img: './..',
        onClick: async () => {
          instance.UI.loadDocument(blob, { filename: 'myfile.pdf' });

          console.log('lastFileBlob Loaded',blob)
        }
    });
  });

Could you double check your import logic?

Best Regards,
Jason Hu
Web Development Support Engineer
PDFTron Systems, Inc.
www.pdftron.com