How to change page margins and still have table stretch to fit?
How to change page margins and still have table stretch to fit?
 DaveBoulden            
            
                Posts: 4Questions: 0Answers: 0
DaveBoulden            
            
                Posts: 4Questions: 0Answers: 0            
            I am customizing PDF output from an instance of DataTables in my data extraction app. I have been able to narrow the page margins, but the table doesn't seem to stretch to fit the newly available page space due to the decreased page margins but rather stays at the same width as the available space on the page with standard page margins. I am assuming to max/min column width and overall _maxWidth properties are calculated before the customize function is applied. How can I make the table stretch to fit the newly manipulated page body width?
Here is my PDF customize function:
{ 
    extend: 'pdf', 
    footer: true, 
    orientation: 'landscape',
    title: 'App data PDF',
    pageSize: 'A4',
    customize: function(doc) {
        doc.pageMargins = [ 20, 20, 20, 20 ];
        doc.defaultStyle.fontSize = 6; 
        doc.styles.tableHeader.fontSize = 7;                                                
        doc.styles.tableFooter.fontSize = 7;
        doc.content[1]._maxWidth = 760;             // doesn't seem to change it, last col still truncated
        var rowCount = doc.content[1].table.body.length;
        for (c = 1; c < doc.content[1].table.body[0].length; c++) {     // right align headers for numeric cols
            if (["Revenue","Vol.","Yield"].includes(doc.content[1].table.body[0][c].text)) {
                doc.content[1].table.body[0][c].alignment = 'right';
            };
        }
        for (i = 1; i < rowCount; i++) {
            for (c = 1; c < doc.content[1].table.body[i].length; c++) { // right align numeric cols
                if (["Revenue","Vol.","Yield"].includes(doc.content[1].table.body[0][c].text)) {
                    doc.content[1].table.body[i][c].alignment = 'right';
                };
            }
        }
    }  
},

Replies
This thread here might help, also follow Allan's link there. Instead of
try setting
doc.content[1].table.widths. Hopefully that'll do the trick,Colin
Thank you for the advice. It has improved a bit. The table now uses the full width, but the last column is still truncated slightly, however, this is an improvement.
I set each width to
"auto"as setting them to"*"made each column the same width and it definitely didn't fit the page. I can see this is largely a pdfMake issue and so I'll try focussing my efforts there and will report back if I find a solution.The extra code I used in the
customizefunction was:Actually, I have just discovered something. It seems my final column with no data wasn't actually being truncated, it simply looked that way due to minimal gutters (padding/margin) between columns.
I swapped the last two columns around and it actually looks right now, so your suggested change with my tweak as shown above is a working solution... thank you!
For the sake of completeness for anyone reading this with the same issue, here is my the full
customizecode of my final solution:Nice. thanks for reporting back,
Colin