public static void main(String[] args) {
    ITemplateEngine templateEngine = new FreemarkerTemplateEngine();
    IXDocReport report = new ODTReport();
    report.setDebugger(SysOutDebugger.INSTANCE);
    report.setTemplateEngine(templateEngine);

    FieldsMetadata metadata = new FieldsMetadata();
    metadata.addFieldAsList("lines.reference");
    report.setFieldsMetadata(metadata);

    try {
      // File f = new File();;
      report.load(TestODTWithFreemarker.class.getResourceAsStream("TestODTWithFreemarker.odt"));
      IContext context = report.createContext();
      Project project = new Project("XDocReport");
      context.put("project", project);

      List<Command> commands = new ArrayList<Command>();
      commands.add(new Command("ref1"));
      commands.add(new Command("ref2"));
      context.put("lines", commands);

      context.put("adresse_magasin", "yessssssssssss");
      File file = new File("out/TestODTWithFreemarker_Out.docx");
      report.process(context, new FileOutputStream(file));

    } catch (IOException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    } catch (XDocReportException e) {
      e.printStackTrace();
    }
  }
  public void testImageWithBadFieldsMetadata() throws Exception {
    ODTPreprocessor preprocessor = new ODTPreprocessor();
    InputStream stream = IOUtils.toInputStream(LOGO_IMAGE_XML, "UTF-8");
    StringWriter writer = new StringWriter();

    FieldsMetadata metadata = new FieldsMetadata();
    metadata.addFieldAsImage("XXX");
    IDocumentFormatter formatter = new VelocityDocumentFormatter();

    preprocessor.preprocess("test", stream, writer, metadata, formatter, null);

    assertEquals(LOGO_IMAGE_XML, writer.toString());
  }
  public static void main(String[] args) throws XDocReportException, IOException {

    // 1) Create FieldsMetadata by setting Velocity as template engine
    FieldsMetadata fieldsMetadata = new FieldsMetadata(TemplateEngineKind.Velocity.name());

    // 2) Load fields metadata from Java Class
    fieldsMetadata.load("devicelist", DeviceList.class);
    // Here load is called with true because model is a list of Developer.
    fieldsMetadata.load("devicelistitem", DeviceListItem.class, true);

    // 3) Generate XML fields in the file "project.fields.xml".
    // Extension *.fields.xml is very important to use it with MS Macro XDocReport.dotm
    // FieldsMetadata#saveXML is called with true to indent the XML.
    File xmlFieldsFile = new File("device_list.fields.xml");
    fieldsMetadata.saveXML(new FileOutputStream(xmlFieldsFile), true);
  }
  /* (non-Javadoc)
   * @see fr.opensagres.xdocreport.service.rest.XDocReportService#upload(fr.opensagres.xdocreport.document.domain.ReportRepresentation)
   */
  @POST
  @Path("/upload")
  @Consumes(MediaType.APPLICATION_JSON)
  public void upload(ReportRepresentation report) throws RemoteInvocationException {

    fr.opensagres.xdocreport.template.formatter.FieldsMetadata fieldsMetadata2 =
        new fr.opensagres.xdocreport.template.formatter.FieldsMetadata();
    for (String field : report.getFieldsMetaData()) {
      fieldsMetadata2.addFieldAsList(field);
    }

    try {
      delegate.registerReport(
          report.getReportID(), report.getDocument(), fieldsMetadata2, "Velocity");
    } catch (XDocReportException e) {
      throw new RemoteInvocationException(e.getMessage(), e.getStackTrace());
    }
  }
  public static void main(String[] args) {
    try {
      // 1) Load Docx file by filling Freemarker template engine and cache
      // it to the registry
      String reportId = "DumTest";
      InputStream in =
          MavenProjectDumperWithFreemarker.class.getResourceAsStream(
              "DocxProjectWithFreemarkerList.docx");
      IXDocReport report =
          XDocReportRegistry.getRegistry().loadReport(in, reportId, TemplateEngineKind.Freemarker);

      // IMPORTANT : cache the original document to use dump.
      report.setCacheOriginalDocument(true);

      FieldsMetadata metadata = report.createFieldsMetadata();
      metadata.addFieldAsList("developers.name");
      metadata.addFieldAsList("developers.lastName");
      metadata.addFieldAsList("developers.mail");

      // 2) Create context Java model
      IContext context = report.createContext();
      // populateWithMap( context );
      populateWithPojo(context);

      // Eclipse project dump as folder.
      MavenProjectDumperOptions options = new MavenProjectDumperOptions();
      options.setBaseDir(new File("target/maven-dump-ftl"));

      // EclipseProjectDumper.getInstance().dump( report, context, option, null );
      report.dump(context, options, null);
    } catch (IOException e) {
      e.printStackTrace();
    } catch (XDocReportException e) {
      e.printStackTrace();
    }
  }
  /* (non-Javadoc)
   * @see fr.opensagres.xdocreport.service.rest.XDocReportService#processReport(fr.opensagres.xdocreport.document.domain.ReportAndDataRepresentation)
   */
  @POST
  @Path("/processReport")
  @Consumes(MediaType.APPLICATION_JSON)
  @Produces(MediaType.WILDCARD)
  public byte[] processReport(ReportAndDataRepresentation reportAndDataRepresentation)
      throws RemoteInvocationException {

    System.err.println(reportAndDataRepresentation);
    FieldsMetadata fieldsMetadata = new FieldsMetadata();
    List<String> fields = reportAndDataRepresentation.getFieldsMetaData();
    for (String field : fields) {
      fieldsMetadata.addFieldAsList(field);
    }

    WSOptions wsOptions = reportAndDataRepresentation.getOptions();

    Options options = null;
    if (wsOptions != null) {
      options = Options.getFrom(wsOptions.getFrom()).to(wsOptions.getTo()).via(wsOptions.getVia());
    }

    byte[] result;
    try {
      result =
          delegate.process(
              reportAndDataRepresentation.getDocument(),
              fieldsMetadata,
              reportAndDataRepresentation.getTemplateEngine(),
              reportAndDataRepresentation.getDataContext(),
              options);
    } catch (XDocReportException e) {
      throw new RemoteInvocationException(e.getMessage(), e.getStackTrace());
    }

    return result;
  }
  public void testImageWithSimpleField() throws Exception {
    ODTPreprocessor preprocessor = new ODTPreprocessor();
    InputStream stream = IOUtils.toInputStream(LOGO_IMAGE_XML, "UTF-8");
    StringWriter writer = new StringWriter();

    FieldsMetadata metadata = new FieldsMetadata();
    metadata.addFieldAsImage("logo");
    IDocumentFormatter formatter = new VelocityDocumentFormatter();

    preprocessor.preprocess("test", stream, writer, metadata, formatter, null);

    assertEquals(
        "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>"
            + "<office:document-content xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" "
            + "xmlns:text=\"urn:oasis:names:tc:opendocument:xmlns:text:1.0\" "
            + "xmlns:table=\"urn:oasis:names:tc:opendocument:xmlns:table:1.0\" "
            + "xmlns:svg=\"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\" "
            + "xmlns:xlink=\"http://www.w3.org/1999/xlink\" "
            + "xmlns:draw=\"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\">"
            + "<text:p text:style-name=\"Standard\">"
            + "#set($___imageInfo=$___ImageRegistry.registerImage($logo,'logo',$___context))#if($___imageInfo.NotRemoveImageTemplate)"
            + "<draw:frame draw:style-name=\"fr1\" draw:name=\"logo\" text:anchor-type=\"paragraph\" svg:x=\"69.96pt\" svg:y=\"18.31pt\" "
            // + "svg:width=\"21pt\" "
            + "svg:width=\"${___ImageRegistry.getWidth($___imageInfo,'21pt')}\" "
            // + "svg:height=\"22.51pt\" "
            + "svg:height=\"${___ImageRegistry.getHeight($___imageInfo,'22.51pt')}\" "
            + "draw:z-index=\"0\">"
            + "<draw:image "
            + "xlink:href=\"${___ImageRegistry.getPath($___imageInfo,'Pictures/100000000000001C0000001EE8812A78.png')}\" "
            + "xlink:type=\"simple\" xlink:show=\"embed\" xlink:actuate=\"onLoad\"/>"
            + "</draw:frame>"
            + "#{end}"
            + "Project logo :</text:p>"
            + "</office:document-content>",
        writer.toString());
  }
  @Override
  public Blob renderTemplate(TemplateBasedDocument templateBasedDocument, String templateName)
      throws IOException {

    Blob sourceTemplateBlob = getSourceTemplateBlob(templateBasedDocument, templateName);

    // load the template
    IXDocReport report;
    try {
      report =
          XDocReportRegistry.getRegistry()
              .loadReport(sourceTemplateBlob.getStream(), TemplateEngineKind.Freemarker, false);
    } catch (XDocReportException e) {
      throw new IOException(e);
    }

    // manage parameters
    List<TemplateInput> params = templateBasedDocument.getParams(templateName);
    FieldsMetadata metadata = new FieldsMetadata();
    for (TemplateInput param : params) {
      if (param.getType() == InputType.PictureProperty) {
        metadata.addFieldAsImage(param.getName());
      }
    }
    report.setFieldsMetadata(metadata);

    // fill Freemarker context
    DocumentModel doc = templateBasedDocument.getAdaptedDoc();
    Map<String, Object> ctx = fmContextBuilder.build(doc, templateName);

    XDocReportBindingResolver resolver = new XDocReportBindingResolver(metadata);
    resolver.resolve(params, ctx, templateBasedDocument);

    // add default context vars
    IContext context;
    try {
      context = report.createContext();
    } catch (XDocReportException e) {
      throw new IOException(e);
    }
    for (String key : ctx.keySet()) {
      context.put(key, ctx.get(key));
    }
    // add automatic loop on audit entries
    metadata.addFieldAsList("auditEntries.principalName");
    metadata.addFieldAsList("auditEntries.eventId");
    metadata.addFieldAsList("auditEntries.eventDate");
    metadata.addFieldAsList("auditEntries.docUUID");
    metadata.addFieldAsList("auditEntries.docPath");
    metadata.addFieldAsList("auditEntries.docType");
    metadata.addFieldAsList("auditEntries.category");
    metadata.addFieldAsList("auditEntries.comment");
    metadata.addFieldAsList("auditEntries.docLifeCycle");
    metadata.addFieldAsList("auditEntries.repositoryId");

    File workingDir = getWorkingDir();
    File generated = new File(workingDir, "XDOCReportresult-" + System.currentTimeMillis());
    generated.createNewFile();

    OutputStream out = new FileOutputStream(generated);

    try {
      report.process(context, out);
    } catch (XDocReportException e) {
      throw new IOException(e);
    }

    Blob newBlob = Blobs.createBlob(generated);

    String templateFileName = sourceTemplateBlob.getFilename();

    // set the output file name
    String targetFileExt = FileUtils.getFileExtension(templateFileName);
    String targetFileName =
        FileUtils.getFileNameNoExt(templateBasedDocument.getAdaptedDoc().getTitle());
    targetFileName = targetFileName + "." + targetFileExt;
    newBlob.setFilename(targetFileName);

    // mark the file for automatic deletion on GC
    Framework.trackFile(generated, newBlob);
    return newBlob;
  }
  public static void main(String[] args) throws IOException, XDocReportException, SQLException {

    InputStream in = GenerateDocxReportSimple.class.getResourceAsStream("test1.docx");
    IXDocReport report =
        XDocReportRegistry.getRegistry().loadReport(in, TemplateEngineKind.Velocity);
    FieldsMetadata metadata = report.createFieldsMetadata();
    metadata.load("test", Test.class, false);
    metadata.load("tests", Test.class, true);
    metadata.load("formatter", Formatter.class);
    metadata.load("group", Group.class);
    Test test = new Test(new Date(), "Test");
    List<Test> tests = new ArrayList<Test>();
    tests.add(new Test(new Date(), "Test1"));
    tests.add(new Test(new Date(1000), "Test2"));

    IContext context = report.createContext();
    Formatter formatter = new Formatter();
    context.put("formatter", formatter);
    context.put("group", new Group());
    context.put("test", test);
    context.put("tests", tests);
    List<Map<String, Object>> testMap = new ArrayList<Map<String, Object>>();

    Map<String, Object> map1 = new HashMap<String, Object>();
    map1.put("currentDate", new Date());
    map1.put("name", "Name1");
    map1.put("val", new BigDecimal(10));
    Map<String, Object> map2 = new HashMap<String, Object>();
    map2.put("currentDate", new Date(11110000));
    map2.put("name", "Name1");
    map2.put("val", new BigDecimal(20.1));

    Map<String, Object> map3 = new HashMap<String, Object>();
    map3.put("currentDate", new Date(11110000));
    map3.put("name", "Name1");
    map3.put("val", new BigDecimal(30.1));

    Map<String, Object> map4 = new HashMap<String, Object>();
    map4.put("currentDate", new Date(111110000));
    map4.put("name", "Name2");
    map4.put("val", new BigDecimal(10.5));

    Map<String, Object> map5 = new HashMap<String, Object>();
    map5.put("currentDate", new Date());
    map5.put("name", "Name2");
    map5.put("val", new BigDecimal(11.5));

    testMap.add(map1);
    testMap.add(map2);
    testMap.add(map3);
    testMap.add(map4);
    testMap.add(map5);

    metadata.addFieldAsList("testMap.currentDate");
    metadata.addFieldAsList("testMap.name");
    metadata.addFieldAsList("testMap.val");

    context.put("testMap", testMap);
    OutputStream out = new FileOutputStream(new File("test1_out.docx"));
    report.process(context, out);
  }
  public void testImageWithListFieldInTable() throws Exception {
    ODTPreprocessor preprocessor = new ODTPreprocessor();
    InputStream stream =
        IOUtils.toInputStream(
            "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>"
                + "<office:document-content xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" "
                + "xmlns:text=\"urn:oasis:names:tc:opendocument:xmlns:text:1.0\" "
                + "xmlns:table=\"urn:oasis:names:tc:opendocument:xmlns:table:1.0\" "
                + "xmlns:svg=\"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\" "
                + "xmlns:xlink=\"http://www.w3.org/1999/xlink\" "
                + "xmlns:draw=\"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\">"
                + "<table:table table:name=\"Tableau1\" table:style-name=\"Tableau1\">"
                + "<table:table-column table:style-name=\"Tableau1.A\"/>"
                + "<table:table-column table:style-name=\"Tableau1.B\"/>"
                + "<table:table-column table:style-name=\"Tableau1.C\"/>"
                + "<table:table-column table:style-name=\"Tableau1.D\"/>"
                + "<table:table-row table:style-name=\"Tableau1.1\">"
                + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"P1\">Name</text:p>"
                + "</table:table-cell>"
                + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"P2\">Last name</text:p>"
                + "</table:table-cell>"
                + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"P1\">Mail</text:p>"
                + "</table:table-cell>"
                + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"P1\">Photo</text:p>"
                + "</table:table-cell>"
                + "</table:table-row>"
                + "<table:table-row table:style-name=\"Tableau1.1\">"
                + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"Standard\">"
                + "<text:text-input text:description=\"\">$developers.Name</text:text-input>"
                + "</text:p>"
                + "</table:table-cell>"
                + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"Standard\">"
                + "<text:text-input text:description=\"\">$developers.LastName</text:text-input>"
                + "</text:p>"
                + "</table:table-cell>"
                + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"Standard\">"
                + "<text:text-input text:description=\"\">$developers.Mail</text:text-input>"
                + "</text:p>"
                + "</table:table-cell>"
                + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
                + "<text:p text:style-name=\"Standard\">"
                + "<draw:frame draw:style-name=\"fr1\" draw:name=\"developers.Photo\" text:anchor-type=\"paragraph\" svg:width=\"21pt\" svg:height=\"22.51pt\" draw:z-index=\"0\">"
                + "<draw:image xlink:href=\"Pictures/100000000000001C0000001EE8812A78.png\" xlink:type=\"simple\" xlink:show=\"embed\" xlink:actuate=\"onLoad\"/>"
                + "</draw:frame>"
                + "</text:p>"
                + "</table:table-cell>"
                + "</table:table-row>"
                + "</table:table>"
                + "</office:document-content>",
            "UTF-8");
    StringWriter writer = new StringWriter();

    FieldsMetadata metadata = new FieldsMetadata();
    metadata.addFieldAsList("developers.Photo");
    metadata.addFieldAsImage("developers.Photo");
    IDocumentFormatter formatter = new VelocityDocumentFormatter();

    preprocessor.preprocess("test", stream, writer, metadata, formatter, null);

    assertEquals(
        "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>"
            + "<office:document-content xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" "
            + "xmlns:text=\"urn:oasis:names:tc:opendocument:xmlns:text:1.0\" "
            + "xmlns:table=\"urn:oasis:names:tc:opendocument:xmlns:table:1.0\" "
            + "xmlns:svg=\"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\" "
            + "xmlns:xlink=\"http://www.w3.org/1999/xlink\" "
            + "xmlns:draw=\"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\">"
            + "<table:table table:name=\"Tableau1\" table:style-name=\"Tableau1\">"
            + "<table:table-column table:style-name=\"Tableau1.A\"/>"
            + "<table:table-column table:style-name=\"Tableau1.B\"/>"
            + "<table:table-column table:style-name=\"Tableau1.C\"/>"
            + "<table:table-column table:style-name=\"Tableau1.D\"/>"
            + "<table:table-row table:style-name=\"Tableau1.1\">"
            + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"P1\">Name</text:p>"
            + "</table:table-cell>"
            + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"P2\">Last name</text:p>"
            + "</table:table-cell>"
            + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"P1\">Mail</text:p>"
            + "</table:table-cell>"
            + "<table:table-cell table:style-name=\"Tableau1.A1\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"P1\">Photo</text:p>"
            + "</table:table-cell>"
            + "</table:table-row>"
            + "#foreach($item_developers in $developers)"
            + "<table:table-row table:style-name=\"Tableau1.1\">"
            + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"Standard\">"
            // +
            // "<text:text-input text:description=\"\">$developers.Name</text:text-input>"
            + "$developers.Name"
            + "</text:p>"
            + "</table:table-cell>"
            + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"Standard\">"
            // +
            // "<text:text-input text:description=\"\">$developers.LastName</text:text-input>"
            + "$developers.LastName"
            + "</text:p>"
            + "</table:table-cell>"
            + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"Standard\">"
            // +
            // "<text:text-input text:description=\"\">$developers.Mail</text:text-input>"
            + "$developers.Mail"
            + "</text:p>"
            + "</table:table-cell>"
            + "<table:table-cell table:style-name=\"Tableau1.A2\" office:value-type=\"string\">"
            + "<text:p text:style-name=\"Standard\">"
            + "#set($___imageInfo=$___ImageRegistry.registerImage($item_developers.Photo,'developers.Photo',$___context))#if($___imageInfo.NotRemoveImageTemplate)"
            + "<draw:frame draw:style-name=\"fr1\" draw:name=\"developers.Photo\" text:anchor-type=\"paragraph\" "
            // + "svg:width=\"21pt\" "
            + "svg:width=\"${___ImageRegistry.getWidth($___imageInfo,'21pt')}\" "
            // + "svg:height=\"22.51pt\" "
            + "svg:height=\"${___ImageRegistry.getHeight($___imageInfo,'22.51pt')}\" "
            + "draw:z-index=\"0\">"
            + "<draw:image "
            + "xlink:href=\"${___ImageRegistry.getPath($___imageInfo,'Pictures/100000000000001C0000001EE8812A78.png')}\" "
            + "xlink:type=\"simple\" xlink:show=\"embed\" xlink:actuate=\"onLoad\"/>"
            + "</draw:frame>"
            + "#{end}"
            + "</text:p>"
            + "</table:table-cell>"
            + "</table:table-row>"
            + "#{end}"
            + "</table:table>"
            + "</office:document-content>",
        writer.toString());
  }