JVM based template engine for office document formats (for now DOCX and XLSX).
With jocument you can easily provide custom configurable office templates for your software. The template language uses the familiar curly-brace syntax for placing data into documents (e.g. Name: {{firstName}} {{lastName}}
), provides mechanics for loops and custom placeholders as well as supporting a variety of different data source types (JSON, POJOs, ...) - you can even easily build your own.
We're hosting jocument releases on the repositories GitHub Packages Page:
<dependency>
<groupId>com.docutools</groupId>
<artifactId>jocument</artifactId>
</dependency>
@Test
@DisplayName("Generate a document from a simple template.")
void shouldGenerateSimpleDocument() throws InterruptedException, IOException {
// Arrange
// (1)
Template template = Template.fromClassPath("/templates/word/UserProfileTemplate.docx")
.orElseThrow();
// (2)
PlaceholderResolver resolver = new ReflectionResolver(SampleModelData.PICARD_PERSON);
// Act
// (3)
Document document = template.startGeneration(resolver);
// (4)
document.blockUntilCompletion(60000L); // 1 minute
// Assert
assertThat(document.completed(), is(true));
Desktop.getDesktop().open(document.getPath().toFile());
}
- Loads a template from the classpath. The
Template
class provides multiple static methods to load templates from various sources (file system, network, memory). - A
PlaceholderResolver
is the data source aTemplate
uses to resolve the values for the placeholders placed in the underlying template. Here we choose theReflectionResolver
implementation, which takes a Java POJO as source and resolves the template placeholder against its property names. - A
Template
generates instances ofDocument
s, which persist the filled out template to a file on the local FS.Document
s are generated asynchronously by default (using the ForkJoinPool#commonPool()). - We block until the
Document
generation completes.
The library is developed with JDK 14. You can read further on development and contribution guidelines in CONTRIBUTE.md.
jocument is developed by the employees of DDS GmbH Austria, the company behind the digital construction documentation software docu tools.