X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=mkdru.client.js;h=5c2d0d029e610af495a298f2a1d9c0f84ab2cd23;hb=db5b797778922d50919364399c90411dfdfb712a;hp=86fcf50b39e542c5d3403d4f95712f4d33e71611;hpb=47606bbe03dc3004f1d98c59bc01d6ba12654008;p=mkdru-moved-to-drupal.org.git diff --git a/mkdru.client.js b/mkdru.client.js index 86fcf50..5c2d0d0 100644 --- a/mkdru.client.js +++ b/mkdru.client.js @@ -1,106 +1,170 @@ // Set up namespace and some state. var mkdru = { // Settings to pass to pz2.js - usesessions: Drupal.settings.mkdru.use_sessions === '1', - // showResponseType: 'json', + useSessions: Drupal.settings.mkdru.use_sessions === '1', // Variables - submitted: false, + active: false, pz2: null, totalRec: 0, - sourceMax: Drupal.settings.mkdru.source_max, - subjectMax: Drupal.settings.mkdru.subject_max, - authorMax: Drupal.settings.mkdru.author_max, + pagerRange: 6, pazpar2Path: Drupal.settings.mkdru.pz2_path, - // State + facetContainerSelector: Drupal.settings.mkdru.facetContainerSelector, + // Facets + facets: { + source: { + displayName: Drupal.settings.mkdru.source_dname || "Source", + orderWeight: Drupal.settings.mkdru.source_weight || 1, + pz2Name: 'xtargets', + max: Drupal.settings.mkdru.source_max || 10 + }, + subject: { + displayName: Drupal.settings.mkdru.subject_dname || "Subject", + orderWeight: Drupal.settings.mkdru.source_weight || 2, + pz2Name: 'subject', + max: Drupal.settings.mkdru.subject_max || 10, + multiLimit: true, + limiter: 'su' + }, + author: { + displayName: Drupal.settings.mkdru.author_dname || "Author", + orderWeight: Drupal.settings.mkdru.source_weight || 3, + pz2Name: 'author', + max: Drupal.settings.mkdru.author_max || 10, + multiLimit: false, + limiter: 'au' + } + }, + // State; Keys limit_{facet key} will also be initialised defaultState: { page: 1, perpage: 20, sort: 'relevance', - filter: null, - query:null, + query:'', + recid:null }, state: {}, + realm: '' }; +// Wrapper for jQuery +(function ($) { + // So we can use jQuery BBQ with Drupal 6 and its 1.2.6 jQuery -if (!$.isArray) $.isArray = function( obj ) { - return toString.call(obj) === "[object Array]"; -}, +if (!$.isArray) $.isArray = function(obj) { + return Object.prototype.toString.call(obj) === "[object Array]"; +}; + +// BBQ has no handy way to remove params without changing the hash. +// This takes an object to add and an array of keys to delete. +mkdru.hashAddDelMany = function (add, del) { + var newHash = $.deparam.fragment(); + if (typeof(add) === 'object') + $.extend(newHash, add); + if ($.isArray(del)) + for (var i=0; i < del.length; i++) + if (newHash[del[i]] !== 'undefined') + delete newHash[del[i]]; + return $.param.fragment("#", newHash); +} + +// It's sometimes cumbersome that object literals can't take variable keys. +mkdru.hashAddDelOne = function (key, value, del) { + var toAdd; + var toDel; + if (key && value) { + var toAdd = {}; + toAdd[key] = value; + } + if (del) { + var toDel = []; + toDel.push(del); + } + return mkdru.hashAddDelMany(toAdd, toDel); +} // pz2.js event handlers: mkdru.pz2Init = function () { - if (mkdru.state.query) mkdru.triggerSearch(); - //mkdru.pz2.stat(); + if (mkdru.state.query) { + mkdru.search(); + } + mkdru.pz2.stat(); //mkdru.pz2.bytarget(); }; mkdru.pz2Show = function (data) { mkdru.totalRec = data.merged; - - var pagerHtml = Drupal.theme('mkdruPager', data, mkdru.state.page, - Math.ceil(mkdru.totalRec / mkdru.state.perpage)); - $('.mkdru-pager').html(pagerHtml); - $('.mkdru-next').bind('click', mkdru.nextPage); - $('.mkdru-prev').bind('click', mkdru.prevPage); - - var countsHtml = 'Displaying: ' + (data.start + 1) + ' to ' - + (data.start + data.num) + ' of ' + data.merged + ' (found: ' + data.total + ')'; - $('.mkdru-counts').html(countsHtml); - + $('.mkdru-pager').html(mkdru.generatePager()); + $('.mkdru-counts').html(Drupal.theme('mkdruCounts', data.start + 1, + data.num, data.merged, data.total)); var html = ""; for (var i = 0; i < data.hits.length; i++) { html += Drupal.theme('mkdruResult', data.hits[i], - i + 1 + mkdru.state.perpage * - (mkdru.state.page - 1)); + i + 1 + mkdru.state.perpage * (mkdru.state.page - 1), + "#" + $.param.fragment($.param.fragment( + window.location.href, {recid: data.hits[i].recid})) + "\n" + ); } $('.mkdru-result-list').html(html); - $('.mkdru-result-title').bind('click', mkdru.requestDetail); - $('.mkdru-results').show(); + if (mkdru.state.recid) { + mkdru.pz2.record(mkdru.state.recid); + } + else { + $('.mkdru-results').show(); + } }; mkdru.pz2Status = function (data) { + $('.mkdru-status').html(Drupal.theme('mkdruStatus', data.activeclients, data.clients)); }; -mkdru.pz2Term = function (data) { - var html = ""; - for (var i = 0; i < data.xtargets.length && i < mkdru.sourceMax; i++ ) { - html += Drupal.theme('mkdruTerm', data.xtargets[i].name, data.xtargets[i].freq, - 'mkdru-facet-source', data.xtargets[i].id); +mkdru.contains = function (hash, key, value) { + if (hash[key]) { + if (hash[key].length) { + for (var i=0; i' - + name + ''; - navi.innerHTML += '
'; - mkdru.state.filter = 'pz:id=' + id; - mkdru.resetPage(); - mkdru.pollDropDowns(); - mkdru.search(); - return false; -}; - -mkdru.resetPage = function () { - mkdru.state.page = 1; - mkdru.totalRec = 0; -}; - -mkdru.showPage = function (pageNum) { - mkdru.state.page = pageNum; - mkdru.pz2.showPage(pageNum-1); -}; - -mkdru.requestDetail = function (e) { - mkdru.pz2.record(e.target.parentNode.id.replace('rec_', '')); }; -mkdru.nextPage = function () { - if (mkdru.totalRec - mkdru.state.perpage * mkdru.state.page > 0) { - mkdru.pz2.showNext(); - mkdru.state.page++; +mkdru.generatePager = function () { + // cast page parameter to numeric so we can add to it + if (typeof mkdru.state.page == "string") { + mkdru.state.page = Number(mkdru.state.page); + } + var total = Math.ceil(mkdru.totalRec / mkdru.state.perpage); + var first = (mkdru.state.page - mkdru.pagerRange > 0) + ? mkdru.state.page - mkdru.pagerRange : 1; + var last = first + 2 * mkdru.pagerRange < total + ? first + 2 * mkdru.pagerRange : total; + var prev = null; + var next = null; + var pages = []; + + if ((mkdru.state.page - 1) >= first) { + prev = "#" + $.param.fragment($.param.fragment( + window.location.href, {page: mkdru.state.page - 1})) + } + if ((mkdru.state.page + 1) <= total) { + next = "#" + $.param.fragment($.param.fragment( + window.location.href, {page: mkdru.state.page + 1})) } -}; -mkdru.prevPage = function () { - if (mkdru.pz2.showPrev() != false) { - mkdru.state.page--; + for (var i = first; i <= last; i++) { + pages.push("#" + $.param.fragment($.param.fragment( + window.location.href, {page: i}))); } + + return Drupal.theme('mkdruPager', pages, first, mkdru.state.page, + total, prev, next); }; @@ -258,19 +389,25 @@ $(document).ready(function () { $(window).bind( 'hashchange', mkdru.hashChange); $('.mkdru-search').bind('submit', mkdru.submitQuery); $('.mkdru-search input:text').attr('value', ''); - $('.mkdru-perpage').bind('change', function () { mkdru.pollDropDowns() }); - $('.mkdru-sort').bind('change', function () { mkdru.pollDropDowns() }); + $('.mkdru-perpage').bind('change', mkdru.submitCriteria); + $('.mkdru-sort').bind('change', mkdru.submitCriteria); + + // generate termlist for pz2.js and populate facet limit state + var termlist = []; + for (var key in mkdru.facets) { + termlist.push(mkdru.facets[key].pz2Name); + mkdru.defaultState['limit_' + key] = null; + } - dump("NEW PZ2!\n"); mkdru.pz2 = new pz2( { "onshow": mkdru.pz2Show, "showtime": 500, //each timer (show, stat, term, bytarget) can be specified this way - "pazpar2path": mkdru.pazpar2path, + "pazpar2path": mkdru.pazpar2Path, "oninit": mkdru.pz2Init, "onstat": mkdru.pz2Status, "onterm": mkdru.pz2Term, - "termlist": "xtargets,subject,author", + "termlist": termlist.join(','), "onbytarget": mkdru.pz2ByTarget, - "usesessions" : mkdru.usesessions, + "usesessions" : mkdru.useSessions, "showResponseType": mkdru.showResponseType, "onrecord": mkdru.pz2Record, "autoInit": false } ); @@ -279,16 +416,47 @@ $(document).ready(function () { mkdru.stateFromHash(); // and update UI to match mkdru.uiFromState(); - dump("QUERY:" + mkdru.state.query + "\n"); - + // ting thing if (typeof(Drupal.settings.mkdru.query) !== "undefined") { mkdru.state.query = Drupal.settings.mkdru.query + //force the hash to contain query + mkdru.hashFromState(); } - if (mkdru.usesessions) { + //not running against SP? init, otherwise authenticate + if (mkdru.useSessions) { mkdru.pz2.init(); - } else if (mkdru.state.query) { - mkdru.triggerSearch(); + } else { + //runnin against SP + var user = Drupal.settings.mkdru.sp_user; + var pass = Drupal.settings.mkdru.sp_pass; + var params = {}; + params['command'] = 'auth'; + if (user && pass) { + params['action'] = 'login'; + params['username'] = user; + params['password'] = pass; + } else { + params['action'] = 'ipauth'; + } + var authReq = new pzHttpRequest(mkdru.pazpar2Path, + function (err) { + alert("Authentication against metasearch gateway failed: " +err); + } + ); + authReq.get(params, + function (data) { + var s = data.getElementsByTagName('status'); + if (s.length && Element_getTextContent(s[0]) == "OK") { + mkdru.realm = data.getElementsByTagName('realm'); + mkdru.pz2Init(); + } else { + alert("Malformed response when authenticating against the metasearch" + + " gateway"); + } + } + ); } }); +})(jQuery);