source: other-projects/hathitrust/wcsa/extracted-features-solr/trunk/web-portal/index.js@ 31524

Last change on this file since 31524 was 31524, checked in by davidb, 7 years ago

Main changes: Fix for page/seqnum; group by id; show-hide other languages; sweedish pos language added

File size: 13.2 KB
Line 
1
2//var langs_with_pos =["da","de","en","nl","pt"];
3var langs_with_pos =["en","de","pt","da","nl", "sv"];
4var langs_without_pos =["af","ar","bg","bn","cs","el","es","et","fa","fi","fr","he","hi","hr","hu","id","it","ja","kn","ko","lt","lv","mk","ml","mr","ne","no","pa","pl","ro","ru","sk","sl","so","sq","sv","sw","ta","te","th","tl","tr","uk","ur","vi","zh-cn","zh-tw"];
5
6var num_rows = 20;
7
8function lang_pos_toggle(event) {
9 var $this =$(this);
10 var checked_state = $this.prop("checked");
11
12 var id = $this.attr("id");
13 var split_id = id.split("-");
14 var related_id = split_id[0] + "-pos-choice";
15
16 //console.log("checked state = " + checked_state);
17
18 var disable_state = !checked_state;
19 $('#'+related_id + " *").prop('disabled',disable_state);
20};
21
22function ajax_error(jqXHR, textStatus, errorThrown) {
23 alert('An error occurred... Look at the console (F12 or Ctrl+Shift+I, Console tab) for more information!');
24
25 console.log('jqXHR:' + jqXHR);
26 console.log('textStatus:' + textStatus);
27 console.log('errorThrown:' + errorThrown);
28}
29
30
31function add_titles(json_data) {
32 $.each( json_data, function( htid_with_prefix, htid_val ) {
33 var htid = htid_with_prefix.replace(/^htid:/,"");
34
35 $.each(htid_val.records, function( internalid, metadata ) {
36 var title = metadata.titles[0];
37 $("[name='"+htid+"']").each(function() {$(this).html(title)});
38 console.log(htid + ", title = " + metadata.titles[0]);
39 });
40 });
41}
42
43function show_new_results(delta)
44{
45 $('.search-in-progress').css("cursor","wait");
46
47 store_search_args.start += delta;
48
49 $.ajax({
50 type: 'GET',
51 url: store_search_action,
52 data: store_search_args,
53 dataType: 'json',
54 success: show_results,
55 error: ajax_error
56 });
57}
58
59
60function generate_item(line,id,id_pages)
61{
62 var css_class = (line%2 == 0) ? 'class="evenline"' : 'class="oddline"';
63
64 var html_item = "";
65
66 var id_pages_len = id_pages.length;
67
68 for (var pi=0; pi<id_pages_len; pi++) {
69 var page = id_pages[pi];
70
71 var seqnum = page - 1;
72 var babel_url = "https://babel.hathitrust.org/cgi/pt?id="+id+";view=1up;seq="+seqnum;
73
74 if (id_pages_len>1) {
75
76 if (pi==0) {
77 html_item += '<p ' + css_class + '>';
78 html_item += '<span style="font-style: italic;" name="'+id+'"><span style="cursor: progress;">Loading ...</span></span><br>';
79
80
81 html_item += id + ': <a target="_blank" href="' + babel_url + '">page ' + page + '</a> ';
82 }
83 else {
84 html_item += ', <a target="_blank" href="' + babel_url + '">page ' + page + '</a> ';
85
86 //var result_item = '<a target="_blank" href="' + babel_url + '">' + id + ', page ' + page + '</a>';
87 //result_item += ' <span style="font-style: italic;" name="'+id+'"><span style="cursor: progress;">Loading ...</span></span>';
88 //html_item += '<p ' + css_class + '>'+result_item+'</p>';
89 }
90 }
91 else {
92 html_item += '<p ' + css_class + '>';
93 html_item += ' <span style="font-style: italic;" name="'+id+'"><span style="cursor: progress;">Loading ...</span></span><br>';
94 html_item += '<a target="_blank" href="' + babel_url + '">' + id + ', page ' + page + '</a>';
95 html_item += '</p>';
96 }
97
98 }
99
100 if (id_pages_len>1) {
101 html_item += "</p>";
102 }
103
104 return html_item;
105}
106
107function show_results(jsonData) {
108 var response = jsonData.response;
109 var num_found = response.numFound;
110 var docs = response.docs;
111 var num_docs = docs.length;
112
113 $('.search-in-progress').css("cursor","auto");
114
115 var $search_results = $('#search-results');
116
117 if (num_docs>0) {
118 $search_results.html("<p>Results: " + num_found + " pages matched</p>");
119 var from = parseInt(store_search_args.start);
120 var to = from + num_rows;
121 $search_results.append("<p>Showing matches: "+from+"-" + to + "</p>");
122 }
123 else {
124 $search_results.html("<p>No pages matched your query</p>");
125 }
126
127
128 // https://babel.hathitrust.org/cgi/pt?id=hvd.hnnssu;view=1up;seq=11
129
130 var htids = [];
131
132 var prev_id = null;
133 var prev_pages = [];
134
135 var i=0;
136 var line_num = 0;
137 while (i<num_docs) {
138// for (var i=0; i<num_docs; i++) {
139 var doc = docs[i];
140 var id_and_page = doc.id.split(".page-");
141 var id = id_and_page[0];
142 var seqnum = parseInt(id_and_page[1]);
143 var page = seqnum+1;
144
145 if ((prev_id != null) && (id != prev_id)) {
146 // time to output previous item
147 var html_item = generate_item(line_num,prev_id,prev_pages);
148 $search_results.append(html_item);
149 line_num++;
150 prev_pages = [page];
151 }
152 else {
153 // accumulate pages
154 prev_pages.push(page)
155 }
156
157// var css_class = (i%2 == 0) ? 'class="evenline"' : 'class="oddline"';
158// //var restful_safe_id = id.replace(/\./g,",").replace(/:/g, "+").replace(/\//g, "=");
159
160// var babel_url = "https://babel.hathitrust.org/cgi/pt?id="+id+";view=1up;seq="+seqnum;
161
162// var result_item = '<a target="_blank" href="' + babel_url + '">' + id + ', page ' + page + '</a>';
163// result_item += ' <span style="font-style: italic;" name="'+id+'"><span style="cursor: progress;">Loading ...</span></span>';
164// $search_results.append('<p ' + css_class + '>'+result_item+'</p>');
165
166 htids.push("htid:"+id);
167
168 prev_id = id;
169 i++;
170 }
171
172 var html_item = generate_item(line_num,prev_id,prev_pages);
173 $search_results.append(html_item);
174
175
176 document.location.href="#search-results-anchor";
177
178 var next_prev = '<p style="width:100%;"><div id="search-prev" style="float: left;"><a>&lt; Previous</a></div><div id="search-next" style="float: right;"><a>Next &gt;</a></div></p>';
179
180 $search_results.append(next_prev);
181 $('#search-prev').click(function(event) { show_new_results(-1*num_rows); });
182 $('#search-next').click(function(event) { show_new_results(num_rows); });
183
184 var search_start = store_search_args.start;
185 if (search_start==0) {
186 $('#search-prev').hide();
187 }
188
189 // Example URL for catalog metadata (multiple items)
190 // http://catalog.hathitrust.org/api/volumes/brief/json/id:552;lccn:70628581|isbn:0030110408
191
192 var htids_str = htids.join("|",htids);
193 var cat_url = "http://catalog.hathitrust.org/api/volumes/brief/json/" + htids_str;
194 $.ajax({
195 url: cat_url,
196 dataType: 'jsonp',
197 jsonpCallback: "add_titles"
198 });
199
200
201 //var json_pretty = JSON.stringify(jsonData.response, null, '\t');
202 //$('#search-results').text(json_pretty)
203}
204
205var store_search_args = null;
206var store_search_action = null;
207
208var group_by_vol_checked = 0;
209
210function submit_action(event)
211{
212 event.preventDefault();
213
214 $('.search-in-progress').css("cursor","wait");
215
216 store_search_action = $('#search-form').attr("action");
217
218 var arg_indent = $('#indent').attr('value');
219 var arg_wt = $('#wt').attr('value');
220 var arg_start = $('#start').attr('value');
221 var arg_rows = $('#rows').attr('value');
222 var q_text = $('#q').val();
223
224 group_by_vol_checked = $('#group-results-by-id:checked').length;
225
226
227 if (q_text === "") {
228 $('.search-in-progress').css("cursor","auto");
229 alert("No query term entered");
230 return;
231 }
232
233 var fields = [];
234 //var langs_with_pos = [ "da", "de", "en", "nl", "pt", "se" ];
235 var universal_pos_tags = [ "VERB", "NOUN", "ADJ", "ADV", "ADP", "CONJ", "DET", "NUM", "PRT", "X" ];
236
237 for (var li=0; li<langs_with_pos.length; li++) {
238 var lang = langs_with_pos[li];
239 var lang_enabled_id = lang + "-enabled";
240 var $lang_enabled_cb = $('#'+lang_enabled_id);
241 if ($lang_enabled_cb.is(':checked')) {
242 console.log("Extracting POS tags for: " + lang);
243
244 for (var ti=0; ti<universal_pos_tags.length; ti++) {
245 var tag = universal_pos_tags[ti];
246 var lang_tag_id = lang+"-"+tag+"-htrctoken-cb";
247 var $lang_tag_cb = $('#'+lang_tag_id);
248 if ($lang_tag_cb.is(':checked')) {
249 //var lang_tag_field = "xxxx"+lang+"_"+tag+"_htrctoken";
250 var lang_tag_field = lang+"_"+tag+"_htrctoken";
251 fields.push(lang_tag_field+":"+q_text);
252 }
253 }
254 }
255 }
256
257 for (var li=0; li<langs_without_pos.length; li++) {
258 var lang = langs_without_pos[li];
259 var lang_enabled_id = lang + "-enabled";
260 var $lang_enabled_cb = $('#'+lang_enabled_id);
261
262 if ($lang_enabled_cb.is(':checked')) {
263 console.log("Adding in non-POS field for: " + lang);
264 //var lang_tag_field = "xxxx"+lang+"_htrctoken";
265 var lang_tag_field = lang+"_htrctoken";
266 fields.push(lang_tag_field+":"+q_text);
267 }
268 }
269
270 if (fields.length == 0) {
271 alert("No languages selected");
272 return;
273 }
274
275 var arg_q = fields.join(" OR ");
276
277
278 // Example search on one of the htrc-full-ef fields is:
279 // q=en_NOUN_htrctoken:farming
280
281 store_search_args = { q: arg_q, indent: arg_indent, wt: arg_wt, start: arg_start, rows: arg_rows };
282
283 if (group_by_vol_checked) {
284 store_search_args.sort="id asc";
285 }
286
287
288 $.ajax({
289 type: 'GET',
290 url: store_search_action,
291 data: store_search_args,
292 dataType: 'json',
293 success: show_results,
294 error: ajax_error
295 });
296
297}
298
299function generate_pos_langs()
300{
301 var pos_checkbox = [
302 { pos:"VERB", label:"Verbs", tooltip:"Verbs (all tenses and modes)" },
303 { pos:"NOUN", label:"Nouns", tooltip:"Nouns (common and proper)" },
304 { pos:"ADJ", label:"Adjectives", tooltip: null },
305 { pos:"ADV", label:"Adverbs", tooltip: null },
306 { pos:"ADP", label:"Adpositions", tooltip:"Adpositions (prepositions and postpositions)" },
307 { pos:"CONJ", label:"Conjunctions",tooltip: null },
308 { pos:"DET", label:"Determiners", tooltip: null },
309 { pos:"NUM", label:"Numbers", tooltip:"Cardinal numbers" },
310 { pos:"PRT", label:"Particles", tooltip:"Particles or other function words" },
311 { pos:"X", label:"Other", tooltip:"Other words, such as foreign words, typos, abbreviations"}
312 ];
313
314 var $pos_fieldsets = $('#pos-fieldsets');
315
316 for (var li=0; li<langs_with_pos.length; li++) {
317
318 var l = langs_with_pos[li];
319 var lang_full = isoLangs[l].name;
320 var lang_native_full = isoLangs[l].nativeName;
321 var opt_title = (lang_full !== lang_native_full) ? 'title="'+lang_native_full+'"' : "";
322
323 var opt_enabled = (l == "en") ? 'checked="checked"' : "";
324
325 var legend = "";
326 legend += ' <legend style="margin-bottom: 5px; padding-top: 15px;">\n';
327 legend += ' <input type="checkbox" name="'+l+'-enabled" id="'+l+'-enabled" ' + opt_enabled +'/>\n';
328 legend += ' <span ' + opt_title + '>'+lang_full+':</span>\n';
329 legend += ' </legend>\n';
330
331
332 var check_box_list = [];
333
334 for (var pi=0; pi<pos_checkbox.length; pi++) {
335 var pos_info = pos_checkbox[pi];
336 var pos = pos_info.pos;
337 var label = pos_info.label;
338 var tooltip = pos_info.tooltip;
339 var opt_tooltip = (tooltip != null) ? 'title="'+tooltip+'"' : "";
340
341 var check_box = "";
342 check_box += ' <input type="checkbox" name="'+l+'-'+pos+'-htrctoken-cb" id="'+l+'-'+pos+'-htrctoken-cb" checked="checked" />\n';
343 check_box += ' <label for="'+l+'-'+pos+'-htrctoken-cb" '+opt_tooltip+'>'+label+'</label>\n';
344
345 check_box_list.push(check_box);
346 }
347
348 var fieldset = "";
349 var opt_showhide_class = (li>0) ? 'class="show-hide-lang"' : "";
350
351 if (li==1) {
352 fieldset += '<button id="show-hide-lang">Show other languages ...</button>';
353 }
354
355 fieldset += '<fieldset ' + opt_showhide_class + '>\n';
356 fieldset += legend;
357 fieldset += ' <div id="'+l+'-pos-choice">\n';
358
359 var check_box_join = check_box_list.join('&nbsp;');
360 fieldset += check_box_join;
361
362 fieldset += ' </div>\n';
363 fieldset += '</fieldset>\n';
364
365 $pos_fieldsets.append(fieldset);
366 $('#'+l+'-enabled').click(lang_pos_toggle);
367
368 if (l == "en") {
369 $('#en-pos-choice *').prop('disabled',false);
370 }
371 else {
372 $('#'+l+'-pos-choice *').prop('disabled',true);
373 }
374 }
375
376
377 //$('#en-enabled').click(lang_pos_toggle);
378 //$('#de-enabled').click(lang_pos_toggle);
379 //$('#de-pos-choice *').prop('disabled',true);
380
381 show_hide_lang()
382}
383
384function show_hide_lang()
385{
386 $( "#show-hide-lang" ).click(function(event) {
387 event.preventDefault();
388 if($('.show-hide-lang:visible').length) {
389 $('.show-hide-lang').hide("slide", {direction: "up" } , 1000);
390 $('#show-hide-lang').html("Show other languages ...");
391 }
392 else {
393 $('.show-hide-lang').show("slide", {direction: "up" } , 1000);
394 $('#show-hide-lang').html("Hide other languages ...");
395 }
396 });
397}
398
399function generate_other_langs()
400{
401 // setup other languages
402 // for each 'langs_without_pos' generate HTML of the form:
403 // <input type="checkbox" name="fr-enabled" id="fr-enabled" />French
404 var $other_langs = $('#other-langs');
405
406 for (var i=0; i<langs_without_pos.length; i++) {
407 var lang = langs_without_pos[i];
408 //var labeled_checkbox = '<span style="white-space:nowrap;">\n';
409 var labeled_checkbox = '<nobr>';
410
411 labeled_checkbox += '<input type="checkbox" name="'+lang+'-enabled" id="'+lang+'-enabled" />';
412 /*
413 if (lang === "zh-cn") {
414 console.log("Mapping zh-cn => zh");
415 lang = "zh";
416 }
417 if (lang === "zh-tw") {
418 console.log("Mapping zh-tw => zh");
419 lang = "zh";
420 }
421*/
422 var lang_full = isoLangs[lang].name;
423 var lang_native_full = isoLangs[lang].nativeName;
424 var opt_title = (lang_full !== lang_native_full) ? 'title="'+lang_native_full+'"' : "";
425
426 labeled_checkbox += '<label for="'+lang+'-enabled" style="padding-left: 5px; padding-right: 10px;" ' + opt_title + '>'+lang_full+'</label>';
427 //labeled_checkbox += '</span>\n';
428 labeled_checkbox += '</nobr> ';
429
430 $other_langs.append(labeled_checkbox);
431
432 }
433}
434
435$(function() {
436 generate_pos_langs();
437
438 generate_other_langs();
439
440 $('#search-submit').click(submit_action);
441
442});
Note: See TracBrowser for help on using the repository browser.