No edit summary |
No edit summary |
||
Line 2: | Line 2: | ||
XHtmlReportAsString | XHtmlReportAsString | ||
==== HTML documents ==== | |||
You can also use html templates. If the template used ends with .htm or .html the logic expects a well formed html document and will expand tags just as in OpenDocument formats - but the we will check for row-builders %%+ROWBUILDERTAG& in <nowiki><tr></nowiki> context (html tables) | |||
====XML documents==== | |||
XML is just the more generic case of html. They are treated by the same logic. You can from 20190919 use any xml-tag as row builder. Example<pre> | |||
<SomeXml attrib='%SomeVMColumnAsAttributeresult%'> %SomeOtherVMColumnAsXMLTextresult% <Items> <Item>%%+TheVMNestingColumn% <ContentInItem someattrib='%VMColInNesting%'> %StuffFromViewModelNesting% </ContentInItem> </Item> </Items> </SomeXml> </pre> | |||
====Viewmodel additions==== | ====Viewmodel additions==== | ||
The templates is can be accessed in several different ways; | The templates is can be accessed in several different ways; | ||
Line 22: | Line 28: | ||
|Blob with an uploaded document template, value is expected to be Base64Encoded | |Blob with an uploaded document template, value is expected to be Base64Encoded | ||
|} | |} | ||
When creating OpenDocument documents, consider using the tag '''%meta%''' in your document to get the exact tag list for your document. | When creating OpenDocument documents, consider using the tag '''%meta%''' in your document to get the exact tag list for your document. | ||
Line 58: | Line 35: | ||
2020-04-06: Please also note that we have seen some issues with corrupt downloads when the ods template is created in OpenOffice 4.1.X. If the template is created in Excel is the document downloaded properly. | 2020-04-06: Please also note that we have seen some issues with corrupt downloads when the ods template is created in OpenOffice 4.1.X. If the template is created in Excel is the document downloaded properly. | ||
Revision as of 22:06, 18 June 2020
The HTML generating functions share most of it's code with the OpenDocument functionality.
XHtmlReportAsString
HTML documents
You can also use html templates. If the template used ends with .htm or .html the logic expects a well formed html document and will expand tags just as in OpenDocument formats - but the we will check for row-builders %%+ROWBUILDERTAG& in <tr> context (html tables)
XML documents
XML is just the more generic case of html. They are treated by the same logic. You can from 20190919 use any xml-tag as row builder. Example
<SomeXml attrib='%SomeVMColumnAsAttributeresult%'> %SomeOtherVMColumnAsXMLTextresult% <Items> <Item>%%+TheVMNestingColumn% <ContentInItem someattrib='%VMColInNesting%'> %StuffFromViewModelNesting% </ContentInItem> </Item> </Items> </SomeXml>
Viewmodel additions
The templates is can be accessed in several different ways;
- From an String attribute in a modeled class
- From an URL
- From the local filesystem
- From the database in BLOB attribute in a modeled class (base64 encoded)
The viewmodel providing the report data also has attributes with specific names providing information to the report functionality.
Attribute name | Attribute should evaluate to | Value type and content |
TemplateUrl | The URL or local filename | String with for example http://www.mdriven.net/templates/report.odt or for prototyping c:\\temp\\mytemplate.odt |
TemplateBlob | A class attribute containing the template | Blob with an uploaded document template, value is expected to be Base64Encoded |
When creating OpenDocument documents, consider using the tag %meta% in your document to get the exact tag list for your document.
Copy the tag name including the percent signs from the generated meta tag information (preferable without style). The %meta% must be first string in element in order to be recognized - it is also case sensitive.
If you type it or edit a part of the tag name, your editor can insert invisible control information that's interfere with the merging.
2020-04-06: Please also note that we have seen some issues with corrupt downloads when the ods template is created in OpenOffice 4.1.X. If the template is created in Excel is the document downloaded properly.