From f6e40ea45f5c63c2a3a74b88cec952f50413b19a Mon Sep 17 00:00:00 2001 From: Matheus Cruz Date: Wed, 3 Jul 2024 20:01:29 -0300 Subject: [PATCH] Add documentation for vertx and qute integration --- docs/src/main/asciidoc/qute-reference.adoc | 73 ++++++++++++++++++++++ 1 file changed, 73 insertions(+) diff --git a/docs/src/main/asciidoc/qute-reference.adoc b/docs/src/main/asciidoc/qute-reference.adoc index 82b8259f7aa01..8b89d5118dcef 100644 --- a/docs/src/main/asciidoc/qute-reference.adoc +++ b/docs/src/main/asciidoc/qute-reference.adoc @@ -2650,6 +2650,79 @@ class DetailResource { WARNING: Unlike with `@Inject` the templates obtained via `RestTemplate` are not validated, i.e. the build does not fail if a template does not exist. +[[vertx_integration]] +=== Vert.x Integration + +If you want to use `io.vertx.core.json.JsonObject` as data in your templates, then you will need to add the `quarkus-vertx` extension to your build file if not already part of your dependencies (most applications use this extension by default). + + +[source,xml,role="primary maven-dependency"] +.pom.xml +---- + + io.quarkus + quarkus-vertx + +---- + +[source,gradle,role="secondary gradle-dependency"] +.build.gradle +---- +implementation("io.quarkus:quarkus-vertx") +---- + +With this dependency included, we have a special value resolver for `io.vertx.core.json.JsonObject` which makes it possible to access the properties of a JSON object in a template: + +.src/main/resources/templates/foo.txt +[source,text] +---- +{tool.name} +{tool.fieldNames} +{tool.fields} +{tool.size} +{tool.empty} +{tool.isEmpty} +{tool.get('name')} +{tool.containsKey('name')} +---- + +.QuteVertxIntegration.java +[source,java] +---- +import java.util.HashMap; +import jakarta.inject.Inject; +import io.vertx.core.json.JsonObject; +import io.quarkus.qute.Template; + +public class QuteVertxIntegration { + + @Inject + Template foo; + + public String render() { + HashMap toolMap = new Map(); + toolMap.put("name", "Roq"); + JsonObject jsonObject = new JsonObject(toolMap); + return foo.data("tool", jsonObject).render(); + } +} +---- + +The `QuteVertxIntegration#render()` output should look like: + +[source,text] +---- +Roq +[name] +[name] +1 +false +false +Roq +true +---- + + === Development Mode In the development mode, all files located in `src/main/resources/templates` are watched for changes.