Printing multiple custom detail views page by page can cause problems because they are printed continuously by default and not page by page. I show a simple trick using CSS to solve this problem. This trick is not new - and yet I hope it helps some of you.
Problem
Record after Record but not not page by page:
This is what I have
data:image/s3,"s3://crabby-images/3d90b/3d90bab49853f718650298b8eb104af308c6a4c2" alt=""
This is what I want
data:image/s3,"s3://crabby-images/e78d6/e78d685029c7df2f3c618d82f2d47b688afb7674" alt=""
Custom print templates
For specially adapted printouts you can create your own template in HTML and switch it on in the init-function by changing $options->TemplateDVP
.
function dienstreisen_init(&$options, $memberInfo, &$args) { $options->TemplateDVP = 'templates/dienstreisen_templateDVP_custom.html'; return TRUE; }
This print template can be used for printing a single record...
data:image/s3,"s3://crabby-images/33c34/33c34c1e140ea60c317ed38aa285f78cf789f991" alt=""
With a little work and HTML/CSS knowledge, you can produce quite respectable printouts like this one. In this case it is an internal accounting document for the accounting of travel expenses of employees.
data:image/s3,"s3://crabby-images/a9575/a9575a4a191dd18db9457319d57d054bb9339fb0" alt=""
Batch printing multiple records
The same print template can also be used after selecting multiple records on table view (TV).
data:image/s3,"s3://crabby-images/80617/80617a9cad51d2e54c9a315d04a4bb771e291687" alt=""
It can be problematic that all data records are printed one after the other but not page by page. The red arrows indicate the places where a page-break shoul be, but isn't:
data:image/s3,"s3://crabby-images/fe64a/fe64a6cc25b1ebd530b002238b4caab6b8e5f1f8" alt=""
Page-break options in CSS
There is a simple trick using HTML and CSS in your print template for adding page-breaks after each record:
Add the following line of HTML code at the end of your print template:
<p style="break-after: always;"></p>
or
<p style="page-break-after: always;"></p>
A page break is added after this paragraph - after each record. This leads to exactly the print output I want:
data:image/s3,"s3://crabby-images/b90fc/b90fcca905c56d5736c9f57a886bbd88ebe209d6" alt=""
There are more options for page-break. The following place is a good starting point for learning and experimenting:
- https://developer.mozilla.org/en-US/docs/Web/CSS/break-after
- https://developer.mozilla.org/en-US/docs/Web/CSS/break-before
I hope you enjoyed reading the article and learned something new today
Kind Regards,
Jan