如何在 Magnolia 应用程序中使用 FreeMarker 模板?

How to use a FreeMarker template in a Magnolia App?

我正在使用 Magnolia 5.4 并根据文档开发了一个应用程序: https://documentation.magnolia-cms.com/display/DOCS54/Apps

应用程序在 magnolia 中正确呈现 shell。 打开应用程序会显示一条 «Hello World» 消息,如文档中所述: https://documentation.magnolia-cms.com/display/DOCS54/Programming+an+app#Programminganapp-MainSubApp

我删除了不必要的代码,结果如下:

public class HelloWorldMainSubAppViewImpl implements HelloWorldMainSubAppView {

    private VerticalLayout layout = new VerticalLayout();
    private Listener listener;

    public HelloWorldMainSubAppViewImpl() {
        layout.setMargin(true);
        layout.setSpacing(true);
        layout.addComponent(new Label("Hello World!"));
    }

    @Override
    public Component asVaadinComponent() {
        return layout;
    }
}

我不想使用 Label 组件,而是使用 FreeMarker 模板来定义自定义视图。

通读了文档后,我还没有想出如何做到这一点。

我在这里可能是错的,但据我所知,Freemarker 仅用于创建模板,不幸的是仅限于此。 https://documentation.magnolia-cms.com/display/DOCS60/Template+scripts

另一方面,您想要做的是开发您的自定义应用程序,这里是一个如何做到这一点的示例。 https://documentation.magnolia-cms.com/display/DOCS54/My+first+content+app

此外,如果您有动力迁移到最新的 Magnolia 版本,您可以使用 Content Types.

非常轻松地定义您的自定义应用程序

希望对您有所帮助,

干杯,

这是我的问题的解决方案,基于之前的工作。

这是 «Custom App» 中描述的 «EmbeddedPageSubApp» 方法

  1. 在导航中的某处创建一个常规页面。

  2. 打开配置应用程序,转到 /modules/<APP_NAME>/apps/<APP_NAME>/subApps/main 并向 mainSubApp 添加一个 url 属性,并使用指向先前创建的页面的绝对路径。

  3. 将 class 属性 /modules/<APP_NAME>/apps/<APP_NAME>/subApps/main 的值更改为 info.magnolia.ui.framework.app.embedded.EmbeddedPageSubAppDescriptor

  4. subAppClass属性的值改为info.magnolia.ui.framework.app.embedded.EmbeddedPageSubApp

  5. 如果您不希望该页面可见 restrict 它在 'superuser' 组/角色中的访问权限,以便只有管理员可以使用它。

这将其与 iframe 绑定。您应该选择一个空白模板,因为嵌入页面的导航元素在应用程序中可见。