-
Notifications
You must be signed in to change notification settings - Fork 374
DocxReportingWEBApplicationDispatcherListField
In this section we add fields list like explained in the Docx Reporting Java Main List Field
Here we add a Table in the docx to generate list of developers in a table to generate for instance this report :
[## 1.1 Create Java model - Developer
Create fr.opensagres.xdocreport.samples.docxandvelocity.model.Developer class like this :
package fr.opensagres.xdocreport.samples.docxandvelocity.model;
public class Developer {
private final String name;
private final String lastName;
private final String mail;
public Developer(String name, String lastName, String mail) {
this.name = name;
this.lastName = lastName;
this.mail = mail;
}
public String getName() {
return name;
}
public String getLastName() {
return lastName;
}
public String getMail() {
return mail;
}
}
The Java List of developers (Developer#getName(), Developer#getLastName(), Developer#getMail()) will be registered with developers key. Add a table with 3 cells which contains merge fields :
- $developers.Name
- $developers.LastName
- $developers.Mail
Save your document with name DocxProjectWithVelocityList.docx in the package fr.opensagres.xdocreport.samples.docxandvelocity.web.servlet.
Create fr.opensagres.xdocreport.samples.docxandvelocity.web.dispatcher.DocxProjectWithVelocityListController like this :
package fr.opensagres.xdocreport.samples.docxandvelocity.web.dispatcher;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import fr.opensagres.xdocreport.core.document.DocumentKind;
import fr.opensagres.xdocreport.document.IXDocReport;
import fr.opensagres.xdocreport.document.web.dispatcher.AbstractXDocReportWEBController;
import fr.opensagres.xdocreport.samples.docxandvelocity.model.Developer;
import fr.opensagres.xdocreport.samples.docxandvelocity.model.Project;
import fr.opensagres.xdocreport.template.IContext;
import fr.opensagres.xdocreport.template.TemplateEngineKind;
import fr.opensagres.xdocreport.template.formatter.FieldsMetadata;
public class DocxProjectWithVelocityListController extends
AbstractXDocReportWEBController {
public static final String REPORT_ID = "DocxProjectWithVelocityList.docx";
public DocxProjectWithVelocityListController() {
super(TemplateEngineKind.Velocity, DocumentKind.DOCX);
}
@Override
public InputStream getSourceStream() {
return DocxProjectWithVelocityListController.class
.getResourceAsStream("DocxProjectWithVelocityList.docx");
}
@Override
protected FieldsMetadata createFieldsMetadata() {
FieldsMetadata metadata = new FieldsMetadata();
metadata.addFieldAsList("developers.Name");
metadata.addFieldAsList("developers.LastName");
metadata.addFieldAsList("developers.Mail");
return metadata;
}
@Override
public void populateContext(IContext context, IXDocReport report,
HttpServletRequest request) {
String name = request.getParameter("name");
Project project = new Project(name);
context.put("project", project);
int nbDevelopers = 0;
try {
nbDevelopers = Integer.parseInt(request
.getParameter("nbDevelopers"));
} catch (Throwable e) {
}
List<Developer> developers = new ArrayList<Developer>(nbDevelopers);
for (int i = 0; i < nbDevelopers; i++) {
developers
.add(new Developer("Name" + i, "LastName" + i, "Mail" + i));
}
context.put("developers", developers);
}
}
The new report wait two HTTP parameters for populate data model :
- name which is the project name.
- nbDevelopers which is the number of developpers to display in the table.
The method createFieldsMetadata is implemented for the new report to manage #foreach automaticly before the row table.
Add the new controller to the dispatcher :
package fr.opensagres.xdocreport.samples.docxandvelocity.web.dispatcher;
import fr.opensagres.xdocreport.document.dispatcher.BasicXDocReportDispatcher;
import fr.opensagres.xdocreport.document.web.dispatcher.IXDocReportWEBController;
public class MyDispatcher extends BasicXDocReportDispatcher<IXDocReportWEBController> {
public MyDispatcher() {
register(DocxProjectWithVelocityController.REPORT_ID, new DocxProjectWithVelocityController());
register(DocxProjectWithVelocityListController.REPORT_ID, new DocxProjectWithVelocityListController());
// register another controller....to manage another report
}
}
If you want replace $project.Name with XDocReport and generate 10 row of developers go at this URL :
It generate report like this :
[### POST URLs
To test POST URLs you can modify the JSP DocxReportingWEBApplicationDispatcher#POST_URLs reportDispatcher.jsp) by adding nbDeveloppers combo and the new reportId DocxProjectWithVelocityList.docx in the reportId combo :
<form name="reportDispatcherForm"
action="<%=request.getContextPath()%>/reportDispatcher" method="post">
<table>
<!-- Data Model -->
<tr>
<td>Project (data model) :</td>
<td><input type="text" name="name" value="XDocReport" /></td>
</tr>
<tr>
<td>Nb developers (data model) :</td>
<td><select name="nbDevelopers">
<option value="0">0</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="8">8</option>
<option value="9">9</option>
<option value="10">10</option>
</select></td>
</tr>
<!-- reportId HTTP parameter -->
<tr>
<td>Report :</td>
<td><select name="reportId">
<option value="DocxProjectWithVelocity.docx">DocxProjectWithVelocity.docx</option>
<option value="DocxProjectWithVelocityList.docx">DocxProjectWithVelocityList.docx</option>
</select></td>
</tr>
<!-- processState HTTP parameter -->
<tr>
<td>Process state :</td>
<td><select name="processState">
<option value="original">original</option>
<option value="preprocessed">preprocessed</option>
<option value="generated" selected="selected">generated</option>
</select></td>
</tr>
<!-- dispatch HTTP parameter -->
<tr>
<td>Dispatch :</td>
<td><select name="dispatch">
<option value="download">download</option>
<option value="view">view</option>
</select></td>
</tr>
<!-- entryName HTTP parameter -->
<tr>
<td>Entry name :</td>
<td><select name="entryName">
<option value=""></option>
<option value="word/document.xml">word/document.xml</option>
</select></td>
</tr>
<!-- Generate report -->
<tr>
<td colspan="2"><input type="submit" value="OK"></td>
</tr>
</table>
</form>
If you go at http://localhost:8080/docxandvelocity/reportDispatcher.jsp you can choose nbDevelopers and DocxProjectWithVelocityList.docx as report :
[and generate with OK button this report :
- Overview
- Getting Started
- FAQ
- Which License Applies
- Download
- Developer's Guide
- User's Guide
- Contributor's Guide
- Acknowledgment
- Articles
- Releases