1 |
// WebPAC API |
2 |
// |
3 |
// Documented in this code only, I'm afraid. Beware of dragons! |
4 |
// Dobrica Pavlinusic dpavlin(at)rot13(dot)org 2005-11-22 |
5 |
|
6 |
/* |
7 |
load another template |
8 |
*/ |
9 |
function load_template(template_name) { |
10 |
|
11 |
var old_template = $('template_name').value; |
12 |
|
13 |
Logger.info('load_template: '+template_name+' (old: '+old_template+')'); |
14 |
|
15 |
if (template_name == old_template) { |
16 |
Logger.error('why reload same template?'); |
17 |
return false; |
18 |
} |
19 |
|
20 |
$('template_name').value = template_name; |
21 |
submit_results_form( 1 ); |
22 |
return false; |
23 |
} |
24 |
|
25 |
/* |
26 |
pager |
27 |
*/ |
28 |
function load_results_page(page_nr) { |
29 |
|
30 |
if (parseInt(page_nr) != page_nr) { |
31 |
Logger.error("load_results_page can't parseInt "+page_nr); |
32 |
return false; |
33 |
} |
34 |
|
35 |
var old_page = get_page_nr(); |
36 |
|
37 |
if (page_nr < 1) { |
38 |
Logger.error("load_results_page called with '"+page_nr+"' < 1"); |
39 |
return false; |
40 |
} |
41 |
|
42 |
Logger.info('load_results_page: '+page_nr+' (from page: '+old_page+')'); |
43 |
|
44 |
if (page_nr == old_page) { |
45 |
Logger.error('why reload same page?'); |
46 |
return false; |
47 |
} |
48 |
|
49 |
submit_results_form( page_nr ); |
50 |
|
51 |
return false; |
52 |
} |
53 |
|
54 |
function get_page_nr() { |
55 |
var page_nr = parseInt( $('page_nr').value ) || 1; |
56 |
return page_nr; |
57 |
} |
58 |
|
59 |
function reset_page_nr( nr ) { |
60 |
if (! nr) nr = 1; |
61 |
Logger.info('reset_page_nr to '+nr); |
62 |
$('page_nr').value = nr; |
63 |
} |
64 |
|
65 |
/* syntaxtic sugar */ |
66 |
function set_page_nr(nr) { |
67 |
return load_results_page(nr); |
68 |
} |
69 |
|
70 |
function next_page() { |
71 |
load_results_page( get_page_nr() + 1 ); |
72 |
return false; |
73 |
} |
74 |
|
75 |
function prev_page() { |
76 |
load_results_page( get_page_nr() - 1 ); |
77 |
return false; |
78 |
} |
79 |
|
80 |
/* toggle visibility and replace text with something else */ |
81 |
function toggleLinkAndElement ( link, elementID, text ) { |
82 |
|
83 |
if ( link.innerHTML != text ) { |
84 |
// change link text |
85 |
link.oldInnerHTML = link.innerHTML; |
86 |
link.innerHTML = text; |
87 |
} else { |
88 |
// change it back |
89 |
link.innerHTML = link.oldInnerHTML; |
90 |
} |
91 |
|
92 |
Logger.debug('toggleLinkAndElement '+elementID+': '+Element.visible( elementID )+' text: '+text); |
93 |
|
94 |
Element.toggle( elementID ); |
95 |
|
96 |
// why is this needed, Firefox 1.5? |
97 |
if (Element.visible( elementID )) $( elementID ).style.display = 'block'; |
98 |
|
99 |
return false; |
100 |
} |
101 |
|
102 |
|
103 |
/* |
104 |
submit results form using AJAX |
105 |
*/ |
106 |
function submit_results_form( page_nr ) { |
107 |
var results_form = $('results_form'); |
108 |
|
109 |
if (results_form) { |
110 |
var form_params = Form.serialize( results_form ); |
111 |
|
112 |
var results_div = 'results'; |
113 |
if (! page_nr) { |
114 |
page_nr = get_page_nr() || 0; |
115 |
} else { |
116 |
$('page_nr').value = page_nr; |
117 |
Logger.info("reset page_nr to "+page_nr); |
118 |
} |
119 |
|
120 |
if (page_nr > 1) { |
121 |
results_div += '_' + page_nr; |
122 |
} |
123 |
|
124 |
if (! $( results_div )) { |
125 |
Logger.error('next page div '+results_div+' doesn\'t exist'); |
126 |
results_div = 'results'; |
127 |
} |
128 |
|
129 |
var url = results_form.action; |
130 |
url += '/ajax'; |
131 |
|
132 |
Logger.debug('submit_results_form to '+url+' page:'+page_nr+' div:'+results_div+' params:'+form_params); |
133 |
|
134 |
Logger.info( 'loading page '+page_nr+' into '+results_div ); |
135 |
show_searching( page_nr ); |
136 |
|
137 |
new Ajax.Updater( results_div, url, { |
138 |
parameters: form_params, |
139 |
asynchronous: 1, |
140 |
onComplete: function(request) { |
141 |
Logger.info( 'page '+page_nr+' loaded into '+results_div ); |
142 |
update_results_stat( page_nr ); |
143 |
hide_searching( page_nr ); |
144 |
} |
145 |
} ) ; |
146 |
return false; |
147 |
} else { |
148 |
Logger.debug('no results_form element'); |
149 |
return undef; |
150 |
} |
151 |
return false; |
152 |
} |
153 |
|
154 |
/* |
155 |
helper functions for submit_results_form() |
156 |
*/ |
157 |
|
158 |
var search_active = 0; |
159 |
|
160 |
function show_searching( page_nr ) { |
161 |
Logger.debug('show_searching '+page_nr); |
162 |
var el = 'searching'; |
163 |
if (page_nr && page_nr > 1) el += '_'+page_nr; |
164 |
Element.show( el ); |
165 |
search_active = 1; |
166 |
return false; |
167 |
} |
168 |
|
169 |
function hide_searching( page_nr ) { |
170 |
Logger.debug('hide_searching '+page_nr); |
171 |
var el = 'searching'; |
172 |
if (page_nr && page_nr > 1) { |
173 |
Element.hide('page_'+(page_nr - 1)); |
174 |
} |
175 |
Element.hide( el ); |
176 |
search_active = 0; |
177 |
// new Effect.Appear('results', { duration: 0.3 }); |
178 |
return false; |
179 |
} |
180 |
|
181 |
/* |
182 |
load record nr in some template |
183 |
*/ |
184 |
|
185 |
function load_rec(record_uri, tmp_template_filename) { |
186 |
if (! tmp_template_filename) tmp_template_filename = template_filename; |
187 |
Logger.info('load_rec '+record_uri+' in '+tmp_template_filename); |
188 |
|
189 |
var results_form = $('results_form'); |
190 |
|
191 |
if (results_form) { |
192 |
var args = '?record_uri='+record_uri+'&template_filename='+tmp_template_filename; |
193 |
Logger.debug('Ajax.Updater(results,/search/record) '+args); |
194 |
|
195 |
show_searching(); |
196 |
|
197 |
new Ajax.Updater( 'results', '/search/record'+args, { |
198 |
asynchronous: 1, |
199 |
onComplete: function(request) { |
200 |
hide_searching(); |
201 |
} |
202 |
} ) ; |
203 |
return false; |
204 |
} else { |
205 |
Logger.debug('no results_form element'); |
206 |
return undef; |
207 |
} |
208 |
return false; |
209 |
} |
210 |
|
211 |
/* click on checkbox */ |
212 |
|
213 |
function checkbox_click() { |
214 |
if (search_active) return false; |
215 |
Logger.debug('checkbox_click'); |
216 |
submit_results_form( 1 ); |
217 |
return true; |
218 |
} |
219 |
|
220 |
/* toggle or select checkbox with value toggle */ |
221 |
|
222 |
function checkbox_toggle( name, val ) { |
223 |
return checkbox_magic( name, val, 0 ); |
224 |
} |
225 |
|
226 |
function checkbox_single( name, val ) { |
227 |
return checkbox_magic( name, val, 1 ); |
228 |
} |
229 |
|
230 |
function checkbox_magic( name, val, single ) { |
231 |
|
232 |
Logger.info('checkbox_magic('+name+','+val+','+single+')'); |
233 |
|
234 |
var form = $('results_form'); |
235 |
var inputs = form.getElementsByTagName('input'); |
236 |
|
237 |
for (var i = 0; i < inputs.length; i++) { |
238 |
var input = inputs[i]; |
239 |
if (input.type != 'checkbox') continue; |
240 |
if (single) { |
241 |
input.checked = false; |
242 |
} |
243 |
if (input.name != name || input.value != val) continue; |
244 |
Logger.debug('toggle '+input.name+'='+input.value+' '+input.checked); |
245 |
input.checked = ! input.checked; |
246 |
if (! single) { |
247 |
submit_results_form( 1 ); |
248 |
return false; |
249 |
} |
250 |
} |
251 |
submit_results_form( 1 ); |
252 |
return false; |
253 |
} |
254 |
|
255 |
/* reset form fields in _reset hidden field to nothing */ |
256 |
|
257 |
function reset_form() { |
258 |
Logger.info('reset '+$F('_reset')); |
259 |
|
260 |
var names = new Array(); |
261 |
names = $F('_reset').split(','); |
262 |
for(var i = 0; i < names.length; i++) { |
263 |
Logger.debug('reset '+i+': '+names[i]); |
264 |
$(names[i]).value=''; |
265 |
} |
266 |
|
267 |
var t=$('search_table'); |
268 |
var max_p = t.rows.length; |
269 |
for(var i = 0; i < attr_rows.length; i++) { |
270 |
var p = attr_rows[i]; |
271 |
if (p != -1) { |
272 |
if (p < max_p) { |
273 |
Logger.debug('delete row '+p); |
274 |
t.deleteRow( p ); |
275 |
} else { |
276 |
Logger.error('skipping invalid delete row '+p); |
277 |
} |
278 |
} |
279 |
} |
280 |
|
281 |
attr_rows = new Array(); |
282 |
|
283 |
return false; |
284 |
} |
285 |
|
286 |
/* helper function for [% search($display, $search, $delimiter) %] */ |
287 |
|
288 |
function search_via_link(attr, val, template) { |
289 |
|
290 |
if (! template) template = $('template_name').value; |
291 |
Logger.info('search called from link for '+attr+'='+val+' in '+template); |
292 |
save_search(attr, val); |
293 |
|
294 |
$('template_name').value = template; |
295 |
submit_results_form( 1 ); |
296 |
|
297 |
return false; |
298 |
} |
299 |
|
300 |
/* save search and add element for it in search form */ |
301 |
|
302 |
var attr_rows = new Array(); |
303 |
|
304 |
function save_search( attr, val ) { |
305 |
Logger.info('save_search('+attr+','+val+')'); |
306 |
|
307 |
var t=$('search_table'); |
308 |
if (! t) { |
309 |
Logger.error("can't find search_table"); |
310 |
return undef; |
311 |
} |
312 |
reset_form(); |
313 |
|
314 |
var form = $('results_form'); |
315 |
var inputs = form.getElementsByTagName('input'); |
316 |
|
317 |
for (var i = 0; i < inputs.length; i++) { |
318 |
var input = inputs[i]; |
319 |
if (input.name != attr) continue; |
320 |
Logger.debug('found '+name+'='+input.value); |
321 |
input.value = unescape( val ); |
322 |
return false; |
323 |
} |
324 |
|
325 |
var t_row_nr = t.rows.length; |
326 |
var tr = t.insertRow( t_row_nr ); |
327 |
|
328 |
if (! tr) { |
329 |
Logger.error("can't create row "+t_row_nr); |
330 |
return undef; |
331 |
} |
332 |
|
333 |
var row_nr = attr_rows.length; |
334 |
attr_rows[ row_nr ] = t_row_nr; |
335 |
|
336 |
Logger.debug('added row '+t_row_nr+' to table [offset: '+row_nr+']'); |
337 |
|
338 |
var td = tr.insertCell(0); |
339 |
td.setAttribute('align', 'right'); |
340 |
td.appendChild( |
341 |
document.createTextNode(attr) |
342 |
); |
343 |
|
344 |
td = tr.insertCell(1); |
345 |
td.setAttribute('align', 'left'); |
346 |
|
347 |
var el = document.createElement('input'); |
348 |
el.setAttribute('type', 'text'); |
349 |
el.setAttribute('disabled', 'true'); |
350 |
el.setAttribute('name', attr); |
351 |
el.setAttribute('id', '_attr_'+attr+'_id'); |
352 |
el.setAttribute('size', val.length < 60 ? 60: val.length); |
353 |
el.setAttribute('value', unescape( val ) ); |
354 |
td.appendChild(el); |
355 |
|
356 |
var el = document.createElement('input'); |
357 |
el.setAttribute('type', 'button'); |
358 |
el.setAttribute('value', '-'); |
359 |
el.onclick = function () { |
360 |
if (attr_rows[row_nr] == -1) { |
361 |
Logger.error('row '+row_nr+' allready deleted'); |
362 |
return false; |
363 |
} |
364 |
Logger.info('remove:' + attr + ' row:'+row_nr+' ['+attr_rows[row_nr]+']'); |
365 |
t.deleteRow( attr_rows[row_nr] ); |
366 |
|
367 |
attr_rows[row_nr] = -1; |
368 |
for (var i=(row_nr + 1); i < attr_rows.length; i++) { |
369 |
attr_rows[i]--; |
370 |
Logger.debug('moved '+i+' to '+attr_rows[i]); |
371 |
} |
372 |
submit_results_form(); |
373 |
return false; |
374 |
} |
375 |
td.appendChild(el); |
376 |
|
377 |
return true; |
378 |
}; |
379 |
|
380 |
/* update number of results for each database */ |
381 |
|
382 |
function update_results_stat( page_nr ) { |
383 |
var el_name = 'results_page_' + page_nr; |
384 |
var all_stats = new Array(); |
385 |
var node_stat = new Array(); |
386 |
|
387 |
var s_el = $( el_name ); |
388 |
|
389 |
if ( s_el ) { |
390 |
all_stats = s_el.value.split(/ /); |
391 |
for (var i = 0; i < all_stats.length; i++) { |
392 |
node_stat = all_stats[i].split(/\//); |
393 |
var result_name = 'node_' + node_stat[0] + '_results'; |
394 |
var u_el = $( result_name ); |
395 |
if (u_el) { |
396 |
Logger.debug("node "+node_stat[0]+" has "+node_stat[1]+" results"); |
397 |
u_el.innerHTML = node_stat[1] + '/'; |
398 |
if (node_stat[1] == 0) |
399 |
Element.hide( 'node_'+node_stat[0] ); |
400 |
else |
401 |
Element.show( 'node_'+node_stat[0] ); |
402 |
} else { |
403 |
Logger.error("can't find " + result_name); |
404 |
} |
405 |
} |
406 |
} else { |
407 |
Logger.error("can't find element "+el_name); |
408 |
} |
409 |
} |
410 |
|
411 |
/* function which is called using DOM.Ready when html_results div is ready */ |
412 |
|
413 |
function results_ready( page_nr ) { |
414 |
if (! page_nr) page_nr = get_page_nr(); |
415 |
Logger.info("html_results ready, page "+page_nr); |
416 |
update_results_stat( page_nr ); |
417 |
var el = $( 'toggle_database_list' ); |
418 |
if (el) { |
419 |
el.onclick() |
420 |
} else { |
421 |
Logger.error("can't find toggle_database_list"); |
422 |
} |
423 |
} |
424 |
|