X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=mkdru.client.js;h=5c2d0d029e610af495a298f2a1d9c0f84ab2cd23;hb=db5b797778922d50919364399c90411dfdfb712a;hp=dae3fa78cf4e47e48d22ad9b2cde30de589b64be;hpb=3f549fb4a29034f2c1aea81f0ec2a0c6b998601e;p=mkdru-moved-to-drupal.org.git diff --git a/mkdru.client.js b/mkdru.client.js index dae3fa7..5c2d0d0 100644 --- a/mkdru.client.js +++ b/mkdru.client.js @@ -2,34 +2,43 @@ var mkdru = { // Settings to pass to pz2.js useSessions: Drupal.settings.mkdru.use_sessions === '1', - // showResponseType: 'json', // Variables active: false, pz2: null, totalRec: 0, pagerRange: 6, pazpar2Path: Drupal.settings.mkdru.pz2_path, + 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 + 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 + 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 + max: Drupal.settings.mkdru.author_max || 10, + multiLimit: false, + limiter: 'au' } }, - // State + // State; Keys limit_{facet key} will also be initialised defaultState: { page: 1, perpage: 20, sort: 'relevance', - filter: null, query:'', recid:null }, @@ -39,6 +48,9 @@ var mkdru = { +// 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 Object.prototype.toString.call(obj) === "[object Array]"; @@ -109,18 +121,49 @@ mkdru.pz2Status = function (data) { $('.mkdru-status').html(Drupal.theme('mkdruStatus', data.activeclients, data.clients)); }; +mkdru.contains = function (hash, key, value) { + if (hash[key]) { + if (hash[key].length) { + for (var i=0; i 0) ? mkdru.state.page - mkdru.pagerRange : 1; var last = first + 2 * mkdru.pagerRange < total - ? first + 2 * mkdru.pagerRange : total; + ? first + 2 * mkdru.pagerRange : total; var prev = null; var next = null; var pages = []; @@ -325,7 +420,10 @@ $(document).ready(function () { // ting thing if (typeof(Drupal.settings.mkdru.query) !== "undefined") { mkdru.state.query = Drupal.settings.mkdru.query + //force the hash to contain query + mkdru.hashFromState(); } + //not running against SP? init, otherwise authenticate if (mkdru.useSessions) { mkdru.pz2.init(); @@ -349,7 +447,7 @@ $(document).ready(function () { ); authReq.get(params, function (data) { - var s = data.getElementsByTagName('status'); + var s = data.getElementsByTagName('status'); if (s.length && Element_getTextContent(s[0]) == "OK") { mkdru.realm = data.getElementsByTagName('realm'); mkdru.pz2Init(); @@ -360,15 +458,5 @@ $(document).ready(function () { } ); } - - //i'm not sure how this can work, does it assume the results set is active? - //what if no search has been executed? - //if (mkdru.state.recid) { - // mkdru.pz2.record(mkdru.state.recid); - //} - //'mkdru.onInit/ deals with the following properly - /// -- waiting for Pz2/SP to init first - //else if (mkdru.state.query) { - // mkdru.search(); - //} }); +})(jQuery);