에셋 검색 확장
- 주제:
- 검색
작성 대상:
- 개발자
Adobe Experience Manager Assets 검색 기능을 확장할 수 있습니다. 기본적으로 Experience Manager Assets은(는) 문자열로 에셋을 검색합니다.
검색은 QueryBuilder 인터페이스를 통해 수행되므로 여러 술어로 검색을 사용자 지정할 수 있습니다. /apps/dam/content/search/searchpanel/facets
디렉터리에 기본 술어 집합을 오버레이할 수 있습니다.
Assets 관리 패널에 탭을 추가할 수도 있습니다.
오버레이
미리 구성된 조건자를 오버레이하려면 facets
노드를 /libs/dam/content/search/searchpanel
에서 /apps/dam/content/search/searchpanel/
(으)로 복사하거나 searchpanel
구성에서 다른 facetURL
속성을 지정하십시오(기본값은 /libs/dam/content/search/searchpanel/facets.overlay.infinity.json
).
/apps
아래의 디렉터리 구조가 없으므로 만듭니다. 노드 유형이 /libs
의 노드 유형과 일치하는지 확인하십시오.탭 추가
Assets 관리 인터페이스에서 검색 탭을 구성하여 추가 검색 탭을 추가할 수 있습니다. 추가 탭을 만들려면 다음 작업을 수행하십시오.
-
폴더 구조
/apps/wcm/core/content/damadmin/tabs,
이(가) 없는 경우 만들고/libs/wcm/core/content/damadmin
에서tabs
노드를 복사하여 붙여 넣습니다. -
원하는 대로 두 번째 탭을 만들고 구성합니다.
NOTE두 번째siteadminsearchpanel
을(를) 만들 때는 양식 충돌을 방지하기 위해id
속성을 설정해야 합니다.
사용자 지정 술어 만들기
Assets에는 자산 공유 페이지를 사용자 지정하는 데 사용할 수 있는 미리 정의된 조건자 집합이 포함되어 있습니다. 이러한 방식으로 자산 공유를 사용자 지정하는 방법은 자산 공유 페이지 만들기 및 구성에서 다룹니다.
Experience Manager 개발자는 기존 술어를 사용할 수 있을 뿐만 아니라 Query Builder API를 사용하여 자체 술어를 만들 수도 있습니다.
사용자 지정 술어를 만들려면 위젯 프레임워크에 대한 기본 지식이 필요합니다.
가장 좋은 방법은 기존 술어를 복사하여 조정하는 것입니다. 샘플 조건자는 /libs/cq/search/components/predicates 에 있습니다.
예: 간단한 속성 설명 작성
속성 술어를 작성하려면 다음을 수행합니다.
-
프로젝트 디렉터리에 구성 요소 폴더(예: /apps/weretail/components/titlepredicate)를 만듭니다.
-
content.xml 추가:
<?xml version="1.0" encoding="UTF-8"?> <jcr:root xmlns:sling="https://sling.apache.org/jcr/sling/1.0" xmlns:cq="https://www.day.com/jcr/cq/1.0" xmlns:jcr="https://www.jcp.org/jcr/1.0" jcr:primaryType="cq:Component" jcr:title="Title Predicate" sling:resourceSuperType="foundation/components/parbase" allowedParents="[*/parsys]" componentGroup="Search"/>
-
titlepredicate.jsp
을(를) 추가합니다.<%-- Sample title predicate component --%><%@ page import="java.util.Calendar" %><% %><%@include file="/libs/foundation/global.jsp"%><% // A unique id is necessary in case this predicate is inserted multiple times on the same page String elemId = "cq-predicate-" + Long.toString(Calendar.getInstance().getTimeInMillis()); %><div class="predicatebox"> <div class="title">Title</div> <%-- The wrapper for the form elements. All items are appended to this wrapper. --%> <div id="<%= elemId %>" class="content"></div> </div><script type="text/javascript"> CQ.Ext.onLoad(function() { var predicateName = "property"; var propertyName = "jcr:content/metadata/dc:title"; var elemId = "<%= elemId %>"; // Get the page wide available QueryBuilder. var qb = CQ.search.Util.getQueryBuilder(); // createId adds a counter to the predicate name - useful in case this predicate // is inserted multiple times on the same page. var id = qb.createId(predicateName); // Hidden field that defines the property to search for; in our case this // is the "dc:title" metadata. The name "property" (or "1_property", "2_property", and so on.) // indicates the server to use the property predicate // (com.day.cq.search.eval.JcrPropertyPredicateEvaluator). qb.addField({ "xtype": "hidden", "renderTo": elemId, "name": id, "value": propertyName }); // The visible text field. The name has to be like the one of the hidden field above // plus the ".value" suffix. qb.addField({ "xtype": "textfield", "renderTo": elemId, "name": id + ".value" }); // Depending on the predicate, additional parameters let you configure the // predicate. Here we add an operation parameter to create a "like" query. // Again note the name set to the id and a suffix. qb.addField({ "xtype": "hidden", "renderTo": elemId, "name": id + ".operation", "value": "like" }); }); </script>
-
To make the component available, you need to be able to edit it. To make a component editable, in CRXDE, add a node cq:editConfig of primary type cq:EditConfig. So that you can remove paragraphs, add a multi-value property cq:actions with a single value of DELETE.
-
브라우저로 이동한 다음 샘플 페이지(예: press.html)에서 디자인 모드로 전환하고 술어 단락 시스템(예: left)에 대한 새 구성 요소를 활성화합니다.
-
편집 모드에서 새 구성 요소를 사이드 킥(검색 그룹에 있음)에서 사용할 수 있습니다. 술어 열에 구성 요소를 삽입하고 검색 단어(예: 다이아몬드)를 입력한 다음 돋보기를 클릭하여 검색을 시작합니다.
NOTE검색할 때는 반드시 정확한 대/소문자를 포함하여 용어를 입력해야 합니다.
예: 간단한 그룹 설명 작성
그룹 설명을 작성하려면 다음을 수행합니다.
-
프로젝트 디렉터리에 구성 요소 폴더(예: /apps/weretail/components/picspredicate)를 만듭니다.
-
content.xml 추가:
<?xml version="1.0" encoding="UTF-8"?> <jcr:root xmlns:sling="https://sling.apache.org/jcr/sling/1.0" xmlns:cq="https://www.day.com/jcr/cq/1.0" xmlns:jcr="https://www.jcp.org/jcr/1.0" jcr:primaryType="cq:Component" jcr:title="Image Formats" sling:resourceSuperType="foundation/components/parbase" allowedParents="[*/parsys]" componentGroup="Search"/>
-
titlepredicate.jsp 추가:
<%-- Sample group predicate component --%><%@ page import="java.util.Calendar" %><% %><%@include file="/libs/foundation/global.jsp"%><% // A unique id is necessary in case this predicate is inserted multiple times on the same page. String elemId = "cq-predicate-" + Long.toString(Calendar.getInstance().getTimeInMillis()); %><div class="predicatebox"> <div class="title">Image Formats</div> <%-- The wrapper for the form elements. All items are append to this wrapper. --%> <div id="<%= elemId %>" class="content"></div> </div><script type="text/javascript"> CQ.Ext.onLoad(function() { var predicateName = "property"; var propertyName = "jcr:content/metadata/dc:format"; var elemId = "<%= elemId %>"; // Get the page wide available QueryBuilder. var qb = CQ.search.Util.getQueryBuilder(); // Create a unique group ID; will return for example, "1_group". var groupId = qb.createGroupId(); // Hidden field that defines the property to search for - in our case "dc:format" - // and declares the group of predicates. "property" in the name ("1_group.property") // indicates to the server to use the "property predicate" // (com.day.cq.search.eval.JcrPropertyPredicateEvaluator). qb.addField({ "xtype": "hidden", "renderTo": "<%= elemId %>", "name": groupId + "." + predicateName, // 1_group.property "value": propertyName }); // Declare to combine the multiple values using OR. qb.add(new CQ.Ext.form.Hidden({ "name": groupId + ".p.or", // 1_group.p.or "value": "true" })); // The options var options = [ { "label":"JPEG", "value":"image/jpeg"}, { "label":"PNG", "value":"image/png" }, { "label":"GIF", "value":"image/gif" } ]; // Build a checkbox for each option. for (var i = 0; i < options.length; i++) { qb.addField({ "xtype": "checkbox", "renderTo": "<%= elemId %>", // 1_group.property.0_value, 1_group.property.1_value, and so on. "name": groupId + "." + predicateName + "." + i + "_value", "inputValue": options[i].value, "boxLabel": options[i].label, "listeners": { "check": function() { // Submit the search form when checking/unchecking a checkbox. qb.submit(); } } }); } });
-
To make the component available, you need to be able to edit it. To make a component editable, in CRXDE, add a node cq:editConfig of primary type cq:EditConfig. So that you can remove paragraphs, add a multi-value property cq:actions with a single value of DELETE.
-
브라우저로 이동한 다음 샘플 페이지(예: press.html)에서 디자인 모드로 전환하고 술어 단락 시스템(예: left)에 대한 새 구성 요소를 활성화합니다.
-
편집 모드에서 새 구성 요소를 사이드 킥(검색 그룹에 있음)에서 사용할 수 있습니다. 조건자 열에 구성 요소를 삽입합니다.
설치된 술어 위젯
다음 조건자는 사전 구성된 ExtJS 위젯으로 사용할 수 있습니다.
전체 텍스트 조건자
fulltext
입니다.keyup
에서 검색을 트리거하기 위한 콜백입니다. 기본값은 CQ.wcm.SiteAdmin.doSearch
입니다.속성 조건자
property
입니다.jcr:title
입니다.경로 조건자
path
입니다./content/dam
입니다.folder
입니다.search in subfolders
확인란을 표시하는 플래그. 기본값은 true입니다.날짜 조건자
daterange
입니다.jcr:content/jcr:lastModified
입니다.옵션 조건자
daterange
입니다.jcr:content/metadata/cq:tags
입니다.level1
입니다.CQ.wcm.SiteAdmin.doSearch
입니다.검색 결과 사용자 지정
자산 공유 페이지에 대한 검색 결과 표시에는 선택한 렌즈가 적용됩니다. Experience Manager Assets에는 자산 공유 페이지를 사용자 지정하는 데 사용할 수 있는 미리 정의된 렌즈 집합이 포함되어 있습니다. 이러한 방식으로 자산 공유를 사용자 지정하는 방법은 자산 공유 페이지 만들기 및 구성에서 다룹니다.
기존 렌즈를 사용하는 것 외에도 Experience Manager명의 개발자가 직접 렌즈를 만들 수도 있습니다.