Interface ReportBuilder<ROOT,​ELEMENT>

All Known Implementing Classes:
ReportDocumentBuilder, ReportJSONBuilder

public interface ReportBuilder<ROOT,​ELEMENT>
  • Method Details

    • createElement

      ReportBuilder<ROOT,​ELEMENT> createElement​(ReportElement value)
      Cria um elemento baseado em um relatório. O builder é 'emprestado' para o relatório, assim, o elemento a ser criado é adicionado ao topo da pilha e depois é removido
      Parameters:
      value - relatório
      Returns:
      builder
    • createElement

      ReportBuilder<ROOT,​ELEMENT> createElement​(String tag, String value)
      Cria um elemento com um conteúdo de texto
      Parameters:
      tag - tag do elemento
      value - valor do elemento
      Returns:
      builder
    • createElement

      ReportBuilder<ROOT,​ELEMENT> createElement​(String tag, Number value)
      Cria um elemento com um conteúdo numérico
      Parameters:
      tag - tag do elemento
      value - valor do elemento
      Returns:
      builder
    • createElement

      ReportBuilder<ROOT,​ELEMENT> createElement​(String tag, boolean value)
      Cria um elemento com um conteúdo booleano
      Parameters:
      tag - tag do elemento
      value - valor do elemento
      Returns:
      builder
    • createElement

      ReportBuilder<ROOT,​ELEMENT> createElement​(String tag, Consumer<ReportBuilder<ROOT,​ELEMENT>> consumer)
      Cria um elemento e o constrói com base em uma função anônima, esse método abstrai a pilha para a criação de elementos complexos.
      Um exemplo do uso é na criação do elemento de certificado em DigitalIdentityReport
      Parameters:
      tag - tag do elemento
      consumer - função de criação do elemento
      Returns:
      builder
      See Also:
      DigitalIdentityReport
    • createElementForEach

      <T> ReportBuilder<ROOT,​ELEMENT> createElementForEach​(String tag, String pluralTag, Collection<T> values, BiConsumer<T,​ReportBuilder<ROOT,​ELEMENT>> consumer)
      Cria uma lista de elementos e os constrói com base em uma função anônima. Esse método abstrai a pilha para a criação de elementos complexos.
      O uso desse método é recomendado para a criação de listas de elementos que não são relatórios. O consumer, ou a função que o implementa, deve receber de argumento o valor T e o builder, nesta ordem.
      Um exemplo do uso é na criação do elemento conformities em Report.buildConformity(SignatureReport.Conformity, ReportBuilder) (SignatureReport.Conformity, ReportBuilder) Report#buildConformity}
      Type Parameters:
      T - tipo dos valores
      Parameters:
      tag - tag do elemento
      pluralTag - tag da lista
      values - valores da lista
      consumer - função de criação do elemento
      Returns:
      builder
    • createElementForEach

      ReportBuilder<ROOT,​ELEMENT> createElementForEach​(Collection<? extends ReportElement> values)

      Este método leva em conta a possibilidade de relatórios de tipos diferentes estarem presentes na lista. Primeiramente, os relatório são agrupados pela tag pluralizada e são adicionados ao elemento com esta tag.

      Caso o elemento com a tag pluralizada não exista, ele é criado.

      Parameters:
      values - relatórios
      Returns:
      builder
    • createElementForEach

      ReportBuilder<ROOT,​ELEMENT> createElementForEach​(String tag, String pluralTag, Collection<String> values)
      Cria um elemento lista (plural tag) e elementos filhos dele com a tag
      Parameters:
      tag - tag dos elementos
      pluralTag - tag lista
      values - valor dos elementos
      Returns:
      builder
    • getCurrentElement

      ELEMENT getCurrentElement()
      Obtém o elemento atual
      Returns:
      elemento atual
    • getRoot

      ROOT getRoot()
      Obtém o elemento raiz
      Returns:
      elemento raiz
    • createElement

      default ReportBuilder<ROOT,​ELEMENT> createElement​(String tag, Date value)