1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34 package info.magnolia.module.samples.model;
35
36 import info.magnolia.cms.core.Content;
37 import info.magnolia.cms.core.MgnlNodeType;
38 import info.magnolia.cms.util.QueryUtil;
39 import info.magnolia.jcr.util.ContentMap;
40 import info.magnolia.rendering.model.RenderingModel;
41 import info.magnolia.rendering.model.RenderingModelImpl;
42 import info.magnolia.rendering.template.RenderableDefinition;
43 import info.magnolia.repository.RepositoryConstants;
44 import info.magnolia.templating.functions.TemplatingFunctions;
45
46 import java.util.ArrayList;
47 import java.util.Collection;
48 import java.util.Iterator;
49 import java.util.List;
50
51 import javax.inject.Inject;
52 import javax.jcr.Node;
53 import javax.jcr.RepositoryException;
54
55
56
57
58
59
60
61
62
63
64 public class SampleComponentModel extends RenderingModelImpl<RenderableDefinition> {
65
66 private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(SampleComponentModel.class);
67
68 private String query;
69 final private TemplatingFunctions functions;
70
71
72 @Inject
73 public SampleComponentModel(Node content, RenderableDefinition definition, RenderingModel<?> parent, TemplatingFunctions functions) {
74 super(content, definition, parent);
75 this.functions = functions;
76 log.info("Running sample component model");
77
78 }
79
80 public String getQuery() {
81 return query;
82 }
83
84 public void setQuery(String query) {
85 this.query = query;
86 }
87
88 public List<ContentMap> getSearchResult() throws RepositoryException{
89
90 String rootPagePath = functions.root(content, MgnlNodeType.NT_PAGE).getPath();
91
92 List<ContentMap> results = new ArrayList<ContentMap>();
93
94 String sql = "SELECT * from nt:base WHERE jcr:path like '"+rootPagePath+"/%' AND contains(*, '"+query+"') AND (jcr:primaryType = 'mgnl:page' OR jcr:primaryType = 'mgnl:area' OR jcr:primaryType = 'mgnl:component') order by jcr:path";
95
96
97 Collection<Content> contentList = QueryUtil.query(RepositoryConstants.WEBSITE, sql);
98 for(Iterator<Content> it=contentList.iterator(); it.hasNext();){
99 results.add(new ContentMap(it.next().getJCRNode()));
100 }
101
102 return results;
103 }
104
105 }