-
Notifications
You must be signed in to change notification settings - Fork 354
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
Generate multiple invoices in one docx, one invoice per page #182
Comments
Same problem for me - multiplying invoices ):. As far as I undestand, your syntax tells that '...contents...' consists of all remaining tags with replacement data, am I correct? Do you put {#invoices} tag at top of page 1 and {/invoice} at top of page 2 (after page break)? Or do you put some command for Word when generating output docx? |
hi, yes '...contents...' is my template of invoice with tags of my invoice data. the {/invoice} is indeed on the page 2 after the page break. in this early test, it is a pure usage of the lib "as is" and it works quite well if you do yourself the templates and if you don't care about the white page at the end. |
for your information, here is a quick hack to automatically add the "array" tags with the page break :
please note that I am note an openXML guru so the breakpage syntax should probably be improved and the last part of the trick (remove the last page break in resulting file) is not done here. disclaimer : this is only a quick hack and use some not documented part of docxtemplater so it may break any moment on a version update ! |
Hi, I am quite nitpicky about integrating new features to docxtemplater. For example, in the past (v0.x), the image module was integrated inside this repository, but it was making the code base more complex and less lightweight (some people use docxtemplater in the browser). Also, it was not easy to add functionality without integrating your code inside the repository (or maintaining a fork). That's why I have created the concept of modules. Modules makes it possible to hook into events triggered by docxtemplater. Here's the code of the image-module : https://github.com/open-xml-templating/docxtemplater-image-module It would be possible to integrate the feature you want in a new module, for example with the following syntax:
You can either do your module yourself (I can help you for specific question if you do it open-source), or we could agree on a contract (in that case, please contact me via email) |
This is a good concept ! I will certainly try to write this module when i'll have some spare time |
@aetna-softwares solution provides what I need, however, it looks like footer and header are not kept in the same loop scope. Any ideas on how to pass along the scope? |
I think that this should be done from word in your template: you should select something like : "apply header to whole document" as far as I can tell. There is also the possibility to use a header for odd page numbers and a header for even page numbers. You could also do it programmatically by copying the content header.xml and create the right rel |
@aetna-softwares, did you ever get this turned into a module? |
Hi, Finally I didn't need it anymore so I didn't take the time to do it. We ended to generate individual documents and when we need some document aggregation we do it on PDF not at the docx generation time. |
Cool. Not a bad approach. |
We're also about to move to what @aetna-softwares described. We've found that with larger documents memory leaks exceed our environment constraints. With 100-200 pages it needs more than 1.5GB RAM. |
I think with the newest version 3.0.2, they shouldn't be any more memory leaks now. |
@aetna-softwares Are you converting from docx to pdf? Are you using LibreOffice or another tool? |
@awerlang yes LibreOffice give me the best results with the best performances (although performances are not so good but others are worse) |
@aetna-softwares Cool! Thanks for sharing! I was working on a Docker image forked from https://hub.docker.com/r/xcgd/py3o.fusion/, hope to add a node server as well. |
There is also the idea of {:join (users,pagebreak)} Would give the desired output (all user information on one page, but without a blank page at the end). |
Does this actually work already, or a proposal for a solution? |
Alive & kicking
…On Feb 3, 2018 3:41 PM, "John" ***@***.***> wrote:
Does this actually work already?
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub
<#182 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/APKj5ZOX9zw_Epl6xil66IwVRlMJUjNQks5tRDfugaJpZM4GkRNj>
.
|
Oh wow nice one! Is there a page for the documentation on this join logic? |
The join syntax is a proposition, it is not implemented get. I posted it here for discussion |
@edi9999 I'm working with a table loop, that contains details for properties of 5 files that I'm documenting and need to place the filename in the footer, so as the filename changes, the footer of that page needs to show the correct one. If this |
Hello @genachka , can you open a new issue for this, and also include screenshots or documents of what you have as data and what ouput you want. ? It doesn't seem to be solvable with the join module. |
Thought i would give this a go this evening, but not making much head way. I can easily inject a page break symbol.. but this still leaves me with a trailing page. I added an index to each page break.. now i only need to remove the last one, but not sure how to access the rendered content to do so.
|
Hello, the different pages in docx are not stored as separate documents, everything is inside the file |
Thanks, I gave this another go this evening.. not too difficult when you know where to look. Here is the code for anyone else stuck in the same boat:
|
can you show me jobdata and reports structure? |
Thank you @edi9999 , this is something that could help me but not in especific how i said i need repeat the same template |
I tried the proposed solution from @jdcrecur but did not work for me.
And then on you doc.setData you can:
|
To avoid having to overwrite the raw_loop_pagebreak in your data, you could also use the {$isLast} trick, documented here : |
The current features of this library are great to generate a "single item" output file, such as for example editing an invoice.
I am looking to an enhancement that allow us to work with the same template but give it an array of data and obtain a document containing all items in one file (such as a mailing in word with an xls file).
the idea is to create each individual files and to concatenate them in a final document with a page break between each item.
I try to get this result by using loop syntax with in page-break inside :
but it has 2 drawbacks :
1/ from a user point of view the {#invoices} tag is difficult to understand as he is creating a template for a single invoice
2/ as I force a page break at the end of content, I have a white page at the end of generated document
A workaround for this 2 point should be to automatically add the {#invoices} tags to the user template before starting the merge and to remove the last page break from the generated file but I would prefer a clean feature than to do this kind of quick hack ;)
do you think that it could be a good feature for your lib ?
The text was updated successfully, but these errors were encountered: