AEM中的OOTB Granite Render渲染条件

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (1)
  • 关注 (0)
  • 查看 (58)

我创建了一个名为的按钮annotation,我添加了hasannotationOOTB Granite Render

渲染条件。在选择具有注释的图像时,该按钮不会被渲染。 自定义按钮的图象有花岗岩的:rendercondition

按钮的属性

花岗岩的属性:渲染条件节点

提问于
用户回答回答于

首先,您需要在您的按钮上添加granite:rel属性。如文档中所述:

这用于表示与HTML rel属性类似的组件的语义关系。

你可以在你的自定义按钮中添加AEM现有花岗岩:rel作为“aem-assets-admin-actions-annotate-activator”如图所示/ libs / dam / gui / content / assets / jcr:content / actions / selection / annotate

或者您也可以添加自定义值,例如“my-annotation-rel”。在这种情况下,您需要告诉AEM考虑您的自定义值。为此,您需要覆盖/libs/dam/gui/coral/components/admin/contentrenderer/base/assetBase.jsp并添加以下行:

 actionRels.add("my-annotation-rel");

更新:渲染条件不起作用,因为路径未正确传递给redercondition组件。{requestPathInfo.suffix}不提供资产的实际路径,而是提供文件夹路径,因此无法检查您何时处于卡片/列/列表视图中。

为了实现这一点,请按照下列步骤操作:

  1. 覆盖/libs/dam/gui/coral/components/admin/contentrenderer/base/base.jsp
  2. 在getActionRels(Node node,boolean hasReplicate,boolean hasRemoveNode,boolean hasModifyAccessControl,boolean isExpiredAsset,boolean isExpiredSubAsset,boolean isDAMAdmin,boolean isContentFragment)方法中添加以下代码 boolean hasAnnotation = false; NodeIterator nodeItr= node.getNodes(); Node commentsNode; while(nodeItr.hasNext()) { Node childNode = nodeItr.nextNode(); NodeIterator childItr = childNode.getNodes(); while(childItr.hasNext()) { Node secondLevelChild = childItr.nextNode(); if(secondLevelChild.getName().equals("comments")) { NodeIterator thirdLevelNode = secondLevelChild.getNodes(); while(thirdLevelNode.hasNext()){ if(thirdLevelNode.nextNode().hasProperty("annotationData")){ hasAnnotation = true; } } } } } if(hasAnnotation){ actionRels.add("my-annotation-rel"); }
  3. 将granite:rel(String)“my-annotation-rel”属性添加到自定义按钮

它应该工作。

另一种不改变OOTB jsp文件行为的方法,如果你是自定义metadataeditor那么花岗岩渲染条件应该工作。在这种情况下,您必须先覆盖此按钮和自定义按钮:

 /libs/dam/gui/content/assets/metadataeditor/jcr:content/actions

并在自定义按钮下添加granite:rendercondition节点,并将path属性设置为

 ${empty requestPathInfo.suffix ? param.item : requestPathInfo.suffix}

所属标签

可能回答问题的人

  • Hanzo

    6 粉丝0 提问7 回答
  • Richel

    9 粉丝0 提问3 回答
  • mariolu

    31 粉丝0 提问2 回答
  • 上云小秘书

    15 粉丝0 提问2 回答

扫码关注云+社区

领取腾讯云代金券