Wiki source code of AutoSuggestWidget

Version 33.1 by Jerome on 2009/10/02

Show last authors
1 1 AutoSuggest Widget
2
3 #startfloatingbox()
4 *Contents*
5 #toc ("2" "2" "")
6 #endfloatingbox()
7
8 #info("This is a Javascript widget bundled by default with the XWiki platform.")
9
10
11 1.1 Usage
12
13 The suggest widget can be triggered when typing something in a text field. The suggested list can contain field values from a class defined in your wiki or any custom information you provide.
14
15 1.1.1 Suggest fields from a class defined in the wiki
16
17 Use information from a predefined class in your wiki (e.g. *XWiki.TagClass*, *XWiki.XWikiUsers*, etc.) or from a class defined by yourself.
18 For example, use *XWiki.TagClass* to suggest tags from the wiki tag cloud:
19
20 {image:suggest.png|document=DevGuide.AutoSuggestWidget}
21 {code}
22
23 $!xwiki.jsx.use("DevGuide.AutoSuggestWidgetExample")
24 <form method="post" action="#">
25 <label for="myinput">Type the name of a tag and test the suggest list:</label>
26 <input id="myinput" size="20" type="text" value=""/>
27 </form>
28
29 {code}
30
31 The *JavascriptExtension* object from the *DevGuide.AutoSuggestWidgetExample* page contains the Javascript code to enable the widget when focusing on the text field:
32
33 {code}
34 (function(){
35 document.observe('dom:loaded', function () {
36 if($('myinput')) {
37 Event.observe($('myinput'), "focus", function() {
38 new ajaxSuggest(this, {script: '$xwiki.getURL("${doc.space}.WebHome", "view")?xpage=suggest&classname=XWiki.TagClass&fieldname=tags&secCol=-&', varname: "input", seps: " ,|", offsety: 13});
39 });
40 }
41 }); // end of doc observe
42 })();
43 {code}
44
45 1.1.1.1 Options used in the *suggest.vm* template:
46
47 {table}
48 Option|Details
49 xpage|Must use *xpage=suggest* because suggest.vm template is used to manage the request.
50 classname|The name of the class for the elements of the suggest list.
51 fieldname|The field name from the class considered for the suggest list.
52 firCol|First column of the list of results.
53 secCol|Second column of the list of results. For a user defined query, use *-* value for one column and no hidden input. Otherwise the list of results will have two columns and a hidden input.
54 {table}
55
56 1.1.1.1 Example
57
58 * Check out the example for class field values at [Class Field Example>DevGuide.AutoSuggestWidgetExample]
59
60
61
62 1.1.1 Suggest custom information
63
64 When the information you want to suggest is not available through a class field or you generate it using a custom query, you need to create a service (plain wiki page called with *xpage=plain* parameter in the url) that maps your results to the *xml* input accepted by the *autosuggest* class.
65 For example, you can build a list of suggestions that contains the wiki page names within a certain space:
66
67 {image:customsuggest.png|document=DevGuide.AutoSuggestWidget}
68
69 {code}
70
71 $!xwiki.jsx.use("DevGuide.AjaxSuggestCustomExample")
72 <form method="post" action="#">
73 <label for="myinput">Type the name of an example page from the *DevGuide* space and test the suggest list:</label>
74 <input id="myinput_suggest" size="20" type="text" value=""/>
75 <input id="myinput" type="hidden" />
76 <input id="mybutton" type="button" value="Go" /><br/>
77 </form>
78
79 {code}
80
81 The *JavascriptExtension* object from the *DevGuide.AjaxSuggestCustomExample* page contains the Javascript code to enable the widget when focusing on the text field. Also, the *script* option uses the url for the results page.
82
83 {code}
84 (function(){
85 document.observe('dom:loaded', function () {
86 if($('myinput_suggest')) {
87 Event.observe($('myinput_suggest'), "focus", function() {
88 new ajaxSuggest(this, {
89 script: "$xwiki.getURL("DevGuide.SuggestService", "view", "xpage=plain&spacename=DevGuide")&",
90 varname: "input",
91 seps: " ,|",
92 offsety: 13,
93 minchars: 3
94 });
95 });
96 }
97 if($('mybutton')) {
98 Event.observe($('mybutton'), "click", function() {
99 location.href = $('myinput').value;
100 });
101 }
102 }); // end of doc observe
103 })();
104 {code}
105 The service page uses a query to get all the pages from the space provided using *spacename* parameter in the url. The generated response must be a *xml* file that has *<results>* as a root node and *<rs>* as children.
106 {code}
107 ##
108 ## Service to generate the suggest list of files from a certain space.
109 ## @spacename
110 ## @input
111 ##
112 #set($input = $request.get("input").toLowerCase())
113 #set($spacename = $request.get("spacename"))
114 $response.setContentType("text/xml") ## generate a xml file
115 ## select pages
116 #if("$!input" == "")
117 #set($query = "where doc.space='$spacename' and doc.name<>'WebHome' and doc.name<>'WebPreferences' order by doc.date desc")
118 #else
119 #set($query = "where doc.space='$spacename' and doc.name<>'WebHome' and doc.name<>'WebPreferences' and lower(doc.name) like '%" + $input + "%' order by doc.date desc")
120 #end
121 #set($searchresults = $xwiki.searchDocuments($query, 30, 0))
122 <results space="$spacename">
123 #foreach($result in $searchresults)
124 #set($resultDoc = $xwiki.getDocument($result))
125 #set($resultDocName = $resultDoc.name)
126 #set($resultDocURL = $resultDoc.getURL())
127 <rs id="1" info="$resultDocURL">$resultDocName</rs>
128 #end
129 </results>
130 {code}
131
132
133 1.1.1.1 Example
134
135 * Check out the example for custom information at [Custom Information Example>DevGuide.AjaxSuggestCustomExample]
136
137 1.1 Javascript parameters for the *ajaxsuggest* class
138
139 {table}
140 Parameter|Details
141 minchars|The minimum number of characters after which to trigger the suggest. Default value is 1.
142 get|The HTTP method for the AJAX request.
143 varname| The name of the request parameter holding the input stub. Default value is *input*.
144 className| The CSS classname of the suggest list. Default value is *ajaxsuggest*.
145 timeout|Default value is *2500*.
146 delay|Default value is *500*.
147 offsety|Default value is *-5*.
148 shownoresults|Display a "no results" message, or simply hide the suggest box when no suggestions are available.
149 noresults|Default displayed message is *No results!*.
150 maxheight|Default value is *250*.
151 cache|Default value is *false*.
152 seps|Default value is "".
153 resultsParameter|The name of the JSON variable or XML element holding the results.Default value is *results* for the old suggest, *searchResults* for the REST search.
154 resultId|The name of the JSON parameter or XML attribute holding the result identifier. DEfault value is *id* for both the old suggest and the REST search.
155 resultValue|The name of the JSON parameter or XML attribute holding the result value.Default *value* for the old suggest, *pageFullName* for the REST page search.
156 resultInfo|The name of the JSON parameter or XML attribute holding the result auxiliary information. Default value is *info* for the old suggest, *pageFullName* for the REST search.
157 parentContainer|The id of the element that will hold the suggest element. Default value is *body*.
158 script|Url for the ajax request that will get the suggested list. Must end with *&* because *varname* parameter will be appended. Use *suggest.vm* to get field values from a wiki class or a custom url to generate the suggested list.
159 {table}
160
161
162 1.1 Tips
163
164 * Check out the Javascript code for more details: *{pre}http://localhost:8080/xwiki/resources/js/xwiki/suggest/ajaxSuggest.js {/pre}*.

Get Connected