X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=www%2Fiphone%2Fexample_client.js;h=9761e831996dcb6ebcedc53d1438c9d6941e5e9a;hb=9b8a842cb328ac45bff04dae8f7e564ba1fc3b3e;hp=b728f959bcd900ada469e73dab8d066c94a7c0d2;hpb=a14c3ce9ee3f8b46f28fb3eaf99e4cb71d3fad18;p=pazpar2-moved-to-github.git
diff --git a/www/iphone/example_client.js b/www/iphone/example_client.js
index b728f95..9761e83 100644
--- a/www/iphone/example_client.js
+++ b/www/iphone/example_client.js
@@ -7,12 +7,15 @@
var usesessions = true;
var pazpar2path = '/pazpar2/search.pz2';
var showResponseType = '';
-if (document.location.hash == '#useproxy') {
+var querys = {'su': '', 'au': '', 'xt': ''};
+
+if (document.location.hash == '#useproxy' || document.location.search.match("useproxy=true")) {
usesessions = false;
pazpar2path = '/service-proxy/';
showResponseType = 'json';
}
+
my_paz = new pz2( { "onshow": my_onshow,
"showtime": 500, //each timer (show, stat, term, bytarget) can be specified this way
"pazpar2path": pazpar2path,
@@ -21,7 +24,7 @@ my_paz = new pz2( { "onshow": my_onshow,
"onterm": my_onterm_iphone,
"termlist": "xtargets,subject,author",
"onbytarget": my_onbytarget,
- "usesessions" : usesessions,
+ "usesessions" : usesessions,
"showResponseType": showResponseType,
"onrecord": my_onrecord } );
// some state vars
@@ -31,17 +34,76 @@ var totalRec = 0;
var curDetRecId = '';
var curDetRecData = null;
var curSort = 'relevance';
-var curFilter = null;
+var curFilter = 'ALL';
var submitted = false;
var SourceMax = 16;
var SubjectMax = 10;
var AuthorMax = 10;
var tab = "recordview";
-var inApp = false;
+var triedPass = "";
+var triedUser = "";
+
+function loginFormSubmit() {
+ triedUser = document.loginForm.username.value;
+ triedPass = document.loginForm.password.value;
+ auth.login( {"username": triedUser,
+ "password": triedPass},
+ authCb, authCb);
+}
+
+function authCb(authData) {
+ if (!authData.loginFailed) {
+ triedUser = "";
+ triedPass = "";
+ }
+
+ if (authData.loggedIn == true) {
+ showhide("recordview");
+ }
+}
+
+function logOutClick() {
+ auth.logOut(authCb, authCb);
+}
+
+function loggedOut() {
+ var login = document.getElementById("login");
+ login.innerHTML = 'Login';
+}
+
+function loggingOutFailed() {
+ alert("Logging out failed");
+}
+
+function login() {
+ showhide("login");
+}
+
+function logout() {
+ auth.logOut(loggedOut, loggingOutFailed, true);
+}
+
+function logInOrOut() {
+ var loginElement = document.getElementById("login");
+ if (loginElement.innerHTML == 'Login')
+ login();
+ else
+ logout();
+}
+function loggedIn() {
+ var login = document.getElementById("login");
+ login.innerHTML = 'Logout(' + auth.displayName + ')';
+ document.getElementById("log").innerHTML = login.innerHTML;
+}
+
+function auth_check() {
+ auth.check(loggedIn, login, true);
+ domReady();
+}
//
-// pz2.js event handlers:
+// Pz2.js event handlers:
//
function my_oninit() {
my_paz.stat();
@@ -58,7 +120,7 @@ function my_onshow(data) {
' of ' + data.merged + ' (found: '
+ data.total + ')';
drawPager(pager);
- // navi
+
var results = document.getElementById("results");
var html = [];
@@ -76,7 +138,7 @@ function my_onshow(data) {
}
}
if (hit.recid == curDetRecId) {
- html.push(renderDetails(curDetRecData));
+ html.push(renderDetails_iphone(curDetRecData));
}
html.push('');
}
@@ -96,127 +158,115 @@ function my_onstat(data) {
}
function showhide(newtab) {
- var showtermlist = false;
- if (newtab != null)
- tab = newtab;
+ var showtermlist = false;
+ if (newtab != null)
+ tab = newtab;
+
+ if (tab == "recordview") {
+ document.getElementById("recordview").style.display = '';
+ }
+ else
+ document.getElementById("recordview").style.display = 'none';
- if (tab == "recordview") {
- document.getElementById("recordview").style.display = '';
- }
- else
- document.getElementById("recordview").style.display = 'none';
+ if (tab == "xtargets") {
+ document.getElementById("term_xtargets").style.display = '';
+ showtermlist = true;
+ }
+ else
+ document.getElementById("term_xtargets").style.display = 'none';
- if (tab == "xtargets") {
- document.getElementById("term_xtargets").style.display = '';
- showtermlist = true;
- }
- else
- document.getElementById("term_xtargets").style.display = 'none';
- if (tab == "subjects") {
- document.getElementById("term_subjects").style.display = '';
- showtermlist = true;
- }
- else
- document.getElementById("term_subjects").style.display = 'none';
- if (tab == "authors") {
- document.getElementById("term_authors").style.display = '';
- showtermlist = true;
- }
- else
- document.getElementById("term_authors").style.display = 'none';
+ if (tab == "subjects") {
+ document.getElementById("term_subjects").style.display = '';
+ showtermlist = true;
+ }
+ else
+ document.getElementById("term_subjects").style.display = 'none';
- if (showtermlist == false)
- document.getElementById("termlist").style.display = 'none';
- else
- document.getElementById("termlist").style.display = '';
+ if (tab == "authors") {
+ document.getElementById("term_authors").style.display = '';
+ showtermlist = true;
+ }
+ else
+ document.getElementById("term_authors").style.display = 'none';
+
+ if (showtermlist == false)
+ document.getElementById("termlist").style.display = 'none';
+ else
+ document.getElementById("termlist").style.display = '';
+
+ var tabDiv = document.getElementById("loginDiv");
+ if (tab == "login") {
+ tabDiv.style.display = '';
+ }
+ else {
+ tabDiv.style.display = 'none';
+ }
}
function my_onterm(data) {
var termlists = [];
termlists.push('
');
- termlists.push('
.::Sources
');
+ termlists.push('
Sources
');
+ termlists.push('
');
termlists.push('
');
termlists.push('');
- termlists.push('
.::Subjects
');
+ termlists.push('
Subjects
');
+ termlists.push('
');
termlists.push('
');
termlists.push('');
- termlists.push('
.::Authors
');
+ termlists.push('
Authors
');
+ termlists.push('
');
termlists.push('
');
var termlist = document.getElementById("termlist");
replaceHtml(termlist, termlists.join(''));
- var d;
-/*
- for (d in ("xtargets", "subjects", "authors")) {
- alert(d);
- if (tab == d)
- document.getElementById("term_" + d).style.display = '';
- else
- document.getElementById("term_" +d ).style.display = 'none';
- }
-*/
showhide();
}
-function serialize(array) {
- var t = typeof (obj);
- if (t != "object" || obj === null) {
- // simple data type
- return String(obj);
- } else {
- // recurse array or object
- var n, v, json = [], arr = (obj && obj.constructor == Array);
- for (n in obj) {
- v = obj[n];
- t = typeof (v);
- if (t == "string")
- v = '"' + v + '"';
- else if (t == "object" && v !== null)
- v = JSON.stringify(v);
- json.push((arr ? "" : '"' + n + '":') + String(v));
- }
- return (arr ? "" : "") + String(json) + (arr ? "]" : "}");
- }
-}
-
var termlist = {};
function my_onterm_iphone(data) {
my_onterm(data);
- var targets = "";
+ var targets = "reset_xt|All\n";
+
for (var i = 0; i < data.xtargets.length; i++ ) {
targets = targets + data.xtargets[i].id + "|" + data.xtargets[i].name + "|" + data.xtargets[i].freq + "\n";
}
termlist["xtargets"] = targets;
- var subjects = "";
+ var subjects = "reset_su|All\n";
for (var i = 0; i < data.subject.length; i++ ) {
- subjects = subjects + "-" + "|" + data.subject[i].name + "|" + data.subject[i].freq + "\n";
+ subjects = subjects + "su" + "|" + data.subject[i].name + "|" + data.subject[i].freq + "\n";
}
termlist["subjects"] = subjects;
- var authors = "";
+ var authors = "reset_au|All\n";
for (var i = 0; i < data.author.length; i++ ) {
- authors = authors + "-" + "|" + data.author[i].name + "|" + data.author[i].freq + "\n";
+ authors = authors + "au" + "|" + data.author[i].name + "|" + data.author[i].freq + "\n";
}
termlist["authors"] = authors;
- //document.getElementById("log").innerHTML = targets + "\n" + subjects + "\n" + authors;
callback.send("termlist", "refresh");
}
@@ -240,7 +290,7 @@ function my_onrecord(data) {
if (detRecordDiv) return;
curDetRecData = data;
var recordDiv = document.getElementById('recdiv_'+curDetRecData.recid);
- var html = renderDetails(curDetRecData);
+ var html = renderDetails_iphone(curDetRecData);
recordDiv.innerHTML += html;
}
@@ -277,18 +327,37 @@ function domReady ()
document.search.query.value = '';
document.select.sort.onchange = onSelectDdChange;
document.select.perpage.onchange = onSelectDdChange;
- if (!inApp)
- document.getElementById("heading").style.display="";
+ if (document.location.search.match("inApp=true"))
+ applicationMode(true);
+ else
+ applicationMode(false);
+}
+
+function applicationMode(newmode)
+{
+ var searchdiv = document.getElementById("searchForm");
+ if (newmode)
+ inApp = newmode;
+ if (inApp) {
+ document.getElementById("heading").style.display="none";
+ searchdiv.style.display = 'none';
+ }
+ else {
+ document.getElementById("nav").style.display="";
+ searchdiv.style.display = '';
+ document.search.onsubmit = onFormSubmit;
+ }
+ callback.init();
}
-
// when search button pressed
function onFormSubmitEventHandler()
{
resetPage();
+ document.getElementById("logo").style.display = 'none';
loadSelect();
triggerSearch();
submitted = true;
- return false;
+ return true;
}
function onSelectDdChange()
@@ -318,21 +387,39 @@ function loadSelect ()
}
// limit the query after clicking the facet
-function limitQuery (field, value)
+function limitQuery(field, value)
{
- document.search.query.value += ' and ' + field + '="' + value + '"';
+ var newQuery = ' and ' + field + '="' + value + '"';
+ querys[field] += newQuery;
+ document.search.query.value += newQuery;
onFormSubmitEventHandler();
showhide("recordview");
}
+//limit the query after clicking the facet
+function removeQuery (field, value) {
+ document.search.query.value.replace(' and ' + field + '="' + value + '"', '');
+ onFormSubmitEventHandler();
+ showhide("recordview");
+}
+
+//limit the query after clicking the facet
+function limitOrResetQuery (field, value, selected) {
+ if (field == 'reset_su' || field == 'reset_au') {
+ var reset_field = field.substring(6);
+ document.search.query.value = document.search.query.value.replace(querys[reset_field], '');
+ querys[reset_field] = '';
+ onFormSubmitEventHandler();
+ showhide("recordview");
+ }
+ else
+ limitQuery(field, value);
+ //alert("limitOrResetQuerry: query after: " + document.search.query.value);
+}
+
// limit by target functions
function limitTarget (id, name)
{
- var navi = document.getElementById('navi');
- navi.innerHTML =
- 'Source: '
- + name + '';
- navi.innerHTML += '
';
curFilter = 'pz:id=' + id;
resetPage();
loadSelect();
@@ -343,15 +430,22 @@ function limitTarget (id, name)
function delimitTarget ()
{
- var navi = document.getElementById('navi');
- navi.innerHTML = '';
- curFilter = null;
+ curFilter = 'ALL';
resetPage();
loadSelect();
triggerSearch();
return false;
}
+function limitOrResetTarget(id, name) {
+ if (id == 'reset_xt') {
+ delimitTarget();
+ }
+ else {
+ limitTarget(id,name);
+ }
+}
+
function drawPager (pagerDiv)
{
//client indexes pages from 1 but pz2 from 0
@@ -394,7 +488,7 @@ function drawPager (pagerDiv)
if (lastClkbl < pages)
postdots = '...';
- pagerDiv.innerHTML += ''
+ pagerDiv.innerHTML += '
'
+ prev + predots + middle + postdots + next + '
';
}
@@ -447,6 +541,7 @@ function showDetails (prefixRecId) {
// remove current detailed view if any
var detRecordDiv = document.getElementById('det_'+oldRecId);
+ //alert("oldRecId: " + oldRecId + " " + detRecordDiv != null);
// lovin DOM!
if (detRecordDiv)
detRecordDiv.parentNode.removeChild(detRecordDiv);
@@ -502,4 +597,62 @@ function renderDetails(data, marker)
details += '
';
return details;
}
- //EOF
+
+function renderLine(title, value) {
+ if (value != undefined)
+ return '' + title + '
' + value + '';
+ return '';
+}
+
+function renderLineURL(title, URL, display) {
+ if (URL != undefined)
+ return '' + title + '
' + display + '';
+ return '';
+}
+
+function renderLineEmail(dtitle, email, display) {
+ if (email != undefined)
+ return '' + title + '
' + display + '';
+ return '';
+}
+
+function renderDetails_iphone(data, marker)
+{
+ //return renderDetails(data,marker);
+
+ if (!data)
+ return "";
+ var details = ''
+/*
+ details = '';
+*/
+ if (marker)
+ details += '
'+ marker + '
';
+ details += '
';
+ if (data["md-title"] != undefined) {
+ details += 'Title
' + data["md-title"];
+ if (data["md-title-remainder"] !== undefined) {
+ details += ' ' + data["md-title-remainder"] + ' ';
+ }
+ if (data["md-title-responsibility"] !== undefined) {
+ details += ''+ data["md-title-responsibility"] +'';
+ }
+ details += ''
+ details += ' '
+ }
+ details
+ +=renderLine('Date', data["md-date"])
+ + renderLine('Author', data["md-author"])
+ + renderLineURL('URL', data["md-electronic-url"], data["md-electronic-url"])
+ + renderLine('Subject', data["location"][0]["md-subject"]);
+
+ if (data["location"][0]["@name"] != undefined)
+ details += renderLine('Location', data["location"][0]["@name"] + " (" +data["location"][0]["@id"] + ")");
+ details += '
';
+ return details;
+}
+
+//EOF