如何在 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» 方法
在导航中的某处创建一个常规页面。
打开配置应用程序,转到 /modules/<APP_NAME>/apps/<APP_NAME>/subApps/main
并向 mainSubApp 添加一个 url 属性,并使用指向先前创建的页面的绝对路径。
将 class 属性 /modules/<APP_NAME>/apps/<APP_NAME>/subApps/main
的值更改为 info.magnolia.ui.framework.app.embedded.EmbeddedPageSubAppDescriptor
将subAppClass
属性的值改为info.magnolia.ui.framework.app.embedded.EmbeddedPageSubApp
如果您不希望该页面可见 restrict 它在 'superuser' 组/角色中的访问权限,以便只有管理员可以使用它。
这将其与 iframe 绑定。您应该选择一个空白模板,因为嵌入页面的导航元素在应用程序中可见。
我正在使用 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» 方法
在导航中的某处创建一个常规页面。
打开配置应用程序,转到
/modules/<APP_NAME>/apps/<APP_NAME>/subApps/main
并向 mainSubApp 添加一个 url 属性,并使用指向先前创建的页面的绝对路径。将 class 属性
/modules/<APP_NAME>/apps/<APP_NAME>/subApps/main
的值更改为info.magnolia.ui.framework.app.embedded.EmbeddedPageSubAppDescriptor
将
subAppClass
属性的值改为info.magnolia.ui.framework.app.embedded.EmbeddedPageSubApp
如果您不希望该页面可见 restrict 它在 'superuser' 组/角色中的访问权限,以便只有管理员可以使用它。
这将其与 iframe 绑定。您应该选择一个空白模板,因为嵌入页面的导航元素在应用程序中可见。